Java10中的非法反射访问操作警告

Illegal reflective access operation warning in Java 10

我将不胜感激重写一些使用反射的 Java 代码,以消除编译器在 Java 10:

上的警告

这是有问题的 Java 方法:

public static boolean clean(final java.nio.ByteBuffer buffer) {
    if (buffer == null || !buffer.isDirect())
        return false;

    Boolean b = (Boolean) AccessController.doPrivileged(new PrivilegedAction() {
        public Object run() {
            Boolean success = Boolean.FALSE;
            try {
                Method getCleanerMethod = buffer.getClass().getMethod("cleaner", (Class[])null);
                getCleanerMethod.setAccessible(true);
                Object cleaner = getCleanerMethod.invoke(buffer, (Object[])null);
                Method clean = cleaner.getClass().getMethod("clean", (Class[])null);
                clean.invoke(cleaner, (Object[])null);
                success = Boolean.TRUE;
            } catch (Exception e) {
                // This really is a show stopper on windows
                //e.printStackTrace();
            }
            return success;
        }
    });

    return b.booleanValue();
}

这是 GitHub 上有问题的代码:https://github.com/LibrePDF/OpenPDF/blob/master/openpdf/src/main/java/com/lowagie/text/pdf/MappedRandomAccessFile.java#L199

这是我在 Java 10:

编译期间收到的警告

WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by com.lowagie.text.pdf.MappedRandomAccessFile (file:/[local path removed from here]/openpdf.jar) to method java.nio.DirectByteBuffer.cleaner() WARNING: Please consider reporting this to the maintainers of com.lowagie.text.pdf.MappedRandomAccessFile WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release

图书馆可以在这里找到:https://github.com/LibrePDF/OpenPDF

关于如何以正确的方式解决这个问题的任何帮助?是否应该重写代码以不使用反射?我可以用受支持的 Java 库中的一些类似代码替换 MappedRandomAccessFile class 吗?

(我是 OpenPDF 的维护者之一,需要一些帮助)

提前致谢!

我看到这个问题已经报告给库的维护者; 参见 https://github.com/LibrePDF/OpenPDF/issues/101

目前,您可以忽略该消息,因为它只是一个警告。

Can I replace the MappedRandomAccessFile class with some similar code in a supported Java library instead?

没有人会阻止你 :-) 但如果你要求推荐,那是题外话。

您的另一种选择是等待 LibrePDF 维护者修复它。

但是,我怀疑他们不会……因为他们做不到。您应该查看 2005 年未解决的 Java 错误报告:https://bugs.java.com/bugdatabase/view_bug.do?bug_id=4724038。我认为这意味着 MappedRandomAccessFile 只能通过修复 Java 错误来修复......这将使对 cleaner() 的非法调用变得不必要。


经过更多挖掘,我发现了这个:

这描述了一个问题,即 GC 对清洁器的调用可能不会 "keep up",从而导致过早的 OOME。这已在 Java 9 中得到修复,并且修复已回溯到 Java 8 和 7。

您需要做的是检查您的代码库的历史和问题,并尝试找出 "cleaner" 代码为何包含在您的 MappedRandomAccessFile class 中。如果它主要是为了解决 JDK-6857566 的问题,那么您现在应该 能够将其删除。