diff options
-rw-r--r-- | libart/src/main/java/java/lang/ref/Reference.java | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/libart/src/main/java/java/lang/ref/Reference.java b/libart/src/main/java/java/lang/ref/Reference.java index 31ea588..70967b5 100644 --- a/libart/src/main/java/java/lang/ref/Reference.java +++ b/libart/src/main/java/java/lang/ref/Reference.java @@ -199,7 +199,19 @@ public abstract class Reference<T> { * @return the referent to which reference refers, or {@code null} if the * object has been cleared. */ - public native T get(); + public T get() { + return getReferent(); + } + + /** + * Returns the referent of the reference object. + * + * @return the referent to which reference refers, or {@code null} if the + * object has been cleared. Required since the compiler + * intrisifies getReferent() since we can't intrinsify Reference.get() + * due to incorrect devirtualization (and inlining) of PhantomReference.get(). + */ + private final native T getReferent(); /** * Checks whether the reference object has been enqueued. |