Skip to content

Commit

Permalink
Merge pull request #20760 from JasonFengJ9/jdk24ref
Browse files Browse the repository at this point in the history
JDK24 removes CleanerImpl.phantomCleanableList
  • Loading branch information
keithc-ca authored Dec 5, 2024
2 parents c714a1e + 108d958 commit 3f7abb5
Showing 1 changed file with 7 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,14 @@
*/
package jdk.internal.ref;

import jdk.internal.ref.CleanerFactory;

import java.lang.ref.Cleaner;
import java.lang.ref.Cleaner.Cleanable;
/*[IF JAVA_SPEC_VERSION < 24]*/
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.security.AccessController;
import java.security.PrivilegedAction;
/*[ENDIF] JAVA_SPEC_VERSION < 24 */

@SuppressWarnings("javadoc")
public class CleanerShutdown {
Expand All @@ -47,14 +47,15 @@ public static void shutdownCleaner() {
}
}

/*[IF JAVA_SPEC_VERSION < 24]*/
try {
Method phantomRemove = PhantomCleanable.class.getDeclaredMethod("remove", (Class<?>[]) null); //$NON-NLS-1$
Method phantomRemove = PhantomCleanable.class.getDeclaredMethod("remove"); //$NON-NLS-1$
AccessController.doPrivileged((PrivilegedAction<Void>) () -> {
phantomRemove.setAccessible(true);
return null;
});
while(!commonCleanerImpl.phantomCleanableList.isListEmpty()) {
phantomRemove.invoke(commonCleanerImpl.phantomCleanableList, (Object[]) null);
while (!commonCleanerImpl.phantomCleanableList.isListEmpty()) {
phantomRemove.invoke(commonCleanerImpl.phantomCleanableList);
}
} catch (NoSuchMethodException
| SecurityException
Expand All @@ -65,5 +66,6 @@ public static void shutdownCleaner() {
/* should not fail */
e.printStackTrace();
}
/*[ENDIF] JAVA_SPEC_VERSION < 24 */
}
}

0 comments on commit 3f7abb5

Please sign in to comment.