mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 14:54:52 +02:00
8188055: (ref) Add Reference::refersTo predicate
Reviewed-by: mchung, pliden, rriggs, dholmes, ihse, smarks, alanb
This commit is contained in:
parent
ab9192e463
commit
6023f6b1bf
13 changed files with 501 additions and 13 deletions
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
|
@ -60,6 +60,14 @@ public class PhantomReference<T> extends Reference<T> {
|
|||
return null;
|
||||
}
|
||||
|
||||
/* Override the implementation of Reference.refersTo.
|
||||
* Phantom references are weaker than finalization, so the referent
|
||||
* access needs to be handled differently for garbage collectors that
|
||||
* do reference processing concurrently.
|
||||
*/
|
||||
@Override
|
||||
native final boolean refersTo0(Object o);
|
||||
|
||||
/**
|
||||
* Creates a new phantom reference that refers to the given object and
|
||||
* is registered with the given queue.
|
||||
|
|
|
@ -325,14 +325,40 @@ public abstract class Reference<T> {
|
|||
* been cleared, either by the program or by the garbage collector, then
|
||||
* this method returns {@code null}.
|
||||
*
|
||||
* @apiNote
|
||||
* This method returns a strong reference to the referent. This may cause
|
||||
* the garbage collector to treat it as strongly reachable until some later
|
||||
* collection cycle. The {@link #refersTo(Object) refersTo} method can be
|
||||
* used to avoid such strengthening when testing whether some object is
|
||||
* the referent of a reference object; that is, use {@code ref.refersTo(obj)}
|
||||
* rather than {@code ref.get() == obj}.
|
||||
*
|
||||
* @return The object to which this reference refers, or
|
||||
* {@code null} if this reference object has been cleared
|
||||
* @see refersTo
|
||||
*/
|
||||
@IntrinsicCandidate
|
||||
public T get() {
|
||||
return this.referent;
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests if the referent of this reference object is {@code obj}.
|
||||
* Using a {@code null} {@code obj} returns {@code true} if the
|
||||
* reference object has been cleared.
|
||||
*
|
||||
* @param obj the object to compare with this reference object's referent
|
||||
* @return {@code true} if {@code obj} is the referent of this reference object
|
||||
* @since 16
|
||||
*/
|
||||
public final boolean refersTo(T obj) {
|
||||
return refersTo0(obj);
|
||||
}
|
||||
|
||||
/* Implementation of refersTo(), overridden for phantom references.
|
||||
*/
|
||||
native boolean refersTo0(Object o);
|
||||
|
||||
/**
|
||||
* Clears this reference object. Invoking this method will not cause this
|
||||
* object to be enqueued.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue