當前位置: 首頁>>代碼示例>>Java>>正文


Java Reference.reachabilityFence方法代碼示例

本文整理匯總了Java中java.lang.ref.Reference.reachabilityFence方法的典型用法代碼示例。如果您正苦於以下問題:Java Reference.reachabilityFence方法的具體用法?Java Reference.reachabilityFence怎麽用?Java Reference.reachabilityFence使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.lang.ref.Reference的用法示例。


在下文中一共展示了Reference.reachabilityFence方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: fenced

import java.lang.ref.Reference; //導入方法依賴的package包/類
public static boolean fenced() {
    AtomicBoolean finalized = new AtomicBoolean();
    MyFinalizeable o = new MyFinalizeable(finalized);

    for (int i = 0; i < LOOP_ITERS; i++) {
        if (finalized.get()) break;
        if (i > WARMUP_LOOP_ITERS) {
            System.gc();
            System.runFinalization();
        }
    }

    Reference.reachabilityFence(o);

    return finalized.get();
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:ReachabilityFenceTest.java

示例2: testCleanupSecret

import java.lang.ref.Reference; //導入方法依賴的package包/類
static void testCleanupSecret(String algorithm) throws Exception {
    KeyGenerator desGen = KeyGenerator.getInstance(algorithm, SunJCEProvider);
    SecretKey key = desGen.generateKey();

    // Break into the implementation to observe the key byte array.
    Class<?> keyClass = key.getClass();
    Field keyField = keyClass.getDeclaredField("key");
    keyField.setAccessible(true);
    byte[] array = (byte[])keyField.get(key);

    byte[] zeros = new byte[array.length];
    do {
        // Wait for array to be cleared;  if not cleared test will timeout
        System.out.printf("%s array: %s%n", algorithm, Arrays.toString(array));
        key = null;
        System.gc();        // attempt to reclaim the key
    } while (Arrays.compare(zeros, array) != 0);
    System.out.printf("%s array: %s%n", algorithm, Arrays.toString(array));

    Reference.reachabilityFence(key); // Keep key alive
    Reference.reachabilityFence(array); // Keep array alive
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:23,代碼來源:DESKeyCleanupTest.java

示例3: testCleanupSecret

import java.lang.ref.Reference; //導入方法依賴的package包/類
static void testCleanupSecret(String algorithm, SecretKey key) throws Exception {

        // Break into the implementation to observe the key byte array.
        Class<?> keyClass = key.getClass();
        Field keyField = keyClass.getDeclaredField("key");
        keyField.setAccessible(true);
        byte[] array = (byte[])keyField.get(key);

        byte[] zeros = new byte[array.length];
        do {
            // Wait for array to be cleared;  if not cleared test will timeout
            System.out.printf("%s array: %s%n", algorithm, Arrays.toString(array));
            key = null;
            System.gc();        // attempt to reclaim the key
        } while (Arrays.compare(zeros, array) != 0);
        System.out.printf("%s array: %s%n", algorithm, Arrays.toString(array));

        Reference.reachabilityFence(key); // Keep key alive
        Reference.reachabilityFence(array); // Keep array alive
    }
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:21,代碼來源:PBEKeyCleanupTest.java

示例4: PhantomCleanable

import java.lang.ref.Reference; //導入方法依賴的package包/類
/**
 * Constructs new {@code PhantomCleanable} with
 * {@code non-null referent} and {@code non-null cleaner}.
 * The {@code cleaner} is not retained; it is only used to
 * register the newly constructed {@link Cleaner.Cleanable Cleanable}.
 *
 * @param referent the referent to track
 * @param cleaner  the {@code Cleaner} to register with
 */
public PhantomCleanable(T referent, Cleaner cleaner) {
    super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
    this.list = CleanerImpl.getCleanerImpl(cleaner).phantomCleanableList;
    insert();

    // Ensure referent and cleaner remain accessible
    Reference.reachabilityFence(referent);
    Reference.reachabilityFence(cleaner);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:19,代碼來源:PhantomCleanable.java

示例5: WeakCleanable

import java.lang.ref.Reference; //導入方法依賴的package包/類
/**
 * Constructs new {@code WeakCleanableReference} with
 * {@code non-null referent} and {@code non-null cleaner}.
 * The {@code cleaner} is not retained by this reference; it is only used
 * to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
 *
 * @param referent the referent to track
 * @param cleaner  the {@code Cleaner} to register new reference with
 */
public WeakCleanable(T referent, Cleaner cleaner) {
    super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
    list = CleanerImpl.getCleanerImpl(cleaner).weakCleanableList;
    insert();

    // Ensure referent and cleaner remain accessible
    Reference.reachabilityFence(referent);
    Reference.reachabilityFence(cleaner);

}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:20,代碼來源:WeakCleanable.java

示例6: SoftCleanable

import java.lang.ref.Reference; //導入方法依賴的package包/類
/**
 * Constructs new {@code SoftCleanableReference} with
 * {@code non-null referent} and {@code non-null cleaner}.
 * The {@code cleaner} is not retained by this reference; it is only used
 * to register the newly constructed {@link Cleaner.Cleanable Cleanable}.
 *
 * @param referent the referent to track
 * @param cleaner  the {@code Cleaner} to register with
 */
public SoftCleanable(T referent, Cleaner cleaner) {
    super(Objects.requireNonNull(referent), CleanerImpl.getCleanerImpl(cleaner).queue);
    list = CleanerImpl.getCleanerImpl(cleaner).softCleanableList;
    insert();

    // Ensure referent and cleaner remain accessible
    Reference.reachabilityFence(referent);
    Reference.reachabilityFence(cleaner);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:19,代碼來源:SoftCleanable.java

示例7: checkShouldNotClear

import java.lang.ref.Reference; //導入方法依賴的package包/類
private void checkShouldNotClear() throws Exception {
    System.out.println("running checkShouldNotClear");
    try {
        int value = 20;
        try {
            remember(value);
            checkValue(value);
            gcUntilOld(testObject);
            // Block concurrent cycle until we're ready.
            WB.requestConcurrentGCPhase("IDLE");
            checkValue(value);
            testObject = null; // Discard strong ref
            // Run through mark_from_roots.
            WB.requestConcurrentGCPhase("BEFORE_REMARK");
            // Fetch weak ref'ed object.  Should be kept alive now.
            Object recovered = getObject();
            if (recovered == null) {
                throw new RuntimeException("unexpected clear during mark");
            }
            // Finish collection, including reference processing.
            // Block any further cycles while we finish check.
            WB.requestConcurrentGCPhase("IDLE");
            // Fetch weak ref'ed object.  Referent is manifestly
            // live in recovered; the earlier fetch should have
            // kept it alive through collection, so weak ref
            // should not have been cleared.
            if (getObject() == null) {
                // 8166188 problem results in not doing the
                // keep-alive of earlier getObject result, so
                // recovered is now reachable but not marked.
                // We may eventually crash.
                throw new RuntimeException("cleared jweak for live object");
            }
            Reference.reachabilityFence(recovered);
        } finally {
            forget();
        }
    } finally {
        // Remove request.
        WB.requestConcurrentGCPhase("ANY");
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:43,代碼來源:TestJNIWeakG1.java

示例8: doClientSide

import java.lang.ref.Reference; //導入方法依賴的package包/類
SBListener doClientSide() throws Exception {

        /*
         * Wait for server to get started.
         */
        while (!serverReady) {
            Thread.sleep(50);
        }

        SSLSocketFactory sslsf =
            (SSLSocketFactory) SSLSocketFactory.getDefault();

        try {
                SSLSocket sslSocket = (SSLSocket)
                    sslsf.createSocket("localhost", serverPort);
                InputStream sslIS = sslSocket.getInputStream();
                OutputStream sslOS = sslSocket.getOutputStream();

            sslOS.write(280);
            sslOS.flush();
            sslIS.read();

            sslOS.close();
            sslIS.close();

            SSLSession sslSession = sslSocket.getSession();
            System.out.printf(" sslSession: %s %n   %s%n", sslSession, sslSession.getClass());
            SBListener sbListener = new SBListener(sslSession);

            sslSession.putValue("x", sbListener);

            sslSession.invalidate();

            sslSocket.close();

            sslOS = null;
            sslIS = null;
            sslSession = null;
            sslSocket = null;
            Reference.reachabilityFence(sslOS);
            Reference.reachabilityFence(sslIS);
            Reference.reachabilityFence(sslSession);
            Reference.reachabilityFence(sslSocket);

            return sbListener;
        } catch (Exception ex) {
            ex.printStackTrace();
            throw ex;
        }
    }
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:51,代碼來源:SSLSessionFinalizeTest.java

示例9: computeIfAbsent

import java.lang.ref.Reference; //導入方法依賴的package包/類
/**
 * If the specified key pair is not already associated with a value,
 * attempts to compute its value using the given mapping function
 * and enters it into this WeakPairMap unless {@code null}. The entire
 * method invocation is performed atomically, so the function is
 * applied at most once per key pair. Some attempted update operations
 * on this WeakPairMap by other threads may be blocked while computation
 * is in progress, so the computation should be short and simple,
 * and must not attempt to update any other mappings of this WeakPairMap.
 *
 * @param k1              the 1st of the pair of keys with which the
 *                        computed value is to be associated
 * @param k2              the 2nd of the pair of keys with which the
 *                        computed value is to be associated
 * @param mappingFunction the function to compute a value
 * @return the current (existing or computed) value associated with
 * the specified key pair, or null if the computed value is null
 * @throws NullPointerException  if any of the specified keys or
 *                               mappingFunction is null
 * @throws IllegalStateException if the computation detectably
 *                               attempts a recursive update to this map
 *                               that would otherwise never complete
 * @throws RuntimeException      or Error if the mappingFunction does so, in
 *                               which case the mapping is left unestablished
 */
public V computeIfAbsent(K1 k1, K2 k2,
                         BiFunction<? super K1, ? super K2, ? extends V>
                             mappingFunction) {
    expungeStaleAssociations();
    try {
        return map.computeIfAbsent(
            Pair.weak(k1, k2, queue),
            pair -> mappingFunction.apply(pair.first(), pair.second()));
    } finally {
        Reference.reachabilityFence(k1);
        Reference.reachabilityFence(k2);
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:39,代碼來源:WeakPairMap.java


注:本文中的java.lang.ref.Reference.reachabilityFence方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。