gpt4 book ai didi

java - Java 10 非法反射访问操作警告

转载 作者:行者123 更新时间:2023-11-30 07:44:56 39 4
gpt4 key购买 nike

如果有人帮助我重写一些使用反射的 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$1 (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$1 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 类吗?

(我是 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 年 Unresolved Java Bug 报告:https://bugs.java.com/bugdatabase/view_bug.do?bug_id=4724038 .我认为这意味着 MappedRandomAccessFile 只能通过修复 Java bug 来修复...这将导致对 cleaner() 的非法调用变得不必要。


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

这描述了一个问题,GC 对清洁器的调用可能无法“跟上”,从而导致过早的 OOME。这已在 Java 9 中得到修复,并且该修复已回溯到 Java 8 和 7。

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

关于java - Java 10 非法反射访问操作警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52232846/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com