jjzjj

java - 不安全的类加载问题?

Unsafe有一个方法来确保类被初始化:Unsafe.ensureClassInitialized(Class)line:notavailable[nativemethod]我怀疑这种类型的初始化不会像常规java类加载那样锁定类,因为我偶尔会遇到一些不可能的情况。如果需要,我稍后可以提供更多详细信息,但是有谁知道使用Unsafe的类加载是否有这样的怪癖?顺便说一句,这里有一个关于如何加载该类的简短堆栈跟踪:Unsafe.ensureClassInitialized(Class)line:notavailable[nativemethod]UnsafeFieldAccessorFact

java - 断言失败 : unsafe symbol DeveloperApi in runtime reflection universe

我在Java8程序中运行以下行SparkConfsparkConf=newSparkConf();sparkConf.setAppName("testJob");sparkConf.setMaster("spark://blahblah:7077");SparkSessionsparkSession=SparkSession.builder().config(sparkConf).getOrCreate();SQLContextsqlContext=newSQLContext(sparkSession);Datasetds=sqlContext.sql("SHOWTABLES");我得

java - 在使用 Gradle 构建的 Groovy 项目中抑制 Java 警告 "Unsafe is internal proprietary API"

我有一个使用Gradle(1.8)构建的Groovy项目,其中一些Java类报告以下编译器警告消息:warning:UnsafeisinternalproprietaryAPIandmayberemovedinafuturereleaseimportsun.misc.Unsafe;有没有办法抑制该错误消息?我找到了一些建议使用javac编译器选项-XDignore.symbol.file的答案,但在使用Groovy插件时我无法将其应用到Gradle构建中。有什么解决办法吗?谢谢 最佳答案 将以下内容添加到您的gradle.build

java - Sonar 标志 "Bad practice": Usage of GetResource in XYZ may be unsafe if class is extended

Sonar在我们的Java项目中指示这个错误。欢迎任何有关安全编程的建议!URLurl=getClass().getResource("/myWonderfulResource.txt");if(url==null){thrownewIllegalStateException("Filenotfound:/myWonderfulResource.txt");} 最佳答案 将类设为final,使其无法扩展。警告是为了防止扩展类(可能)尝试使用不存在的资源。 关于java-Sonar标志"B

java - sun.misc.Unsafe 是否在 JDK9 中公开?

我刚刚尝试了JDK9并发现sun.misc.Unsafe现在不包含本地方法,而是将它们委托(delegate)给一些jdk.internal。misc.Unsafe,例如:@ForceInlinepublicintgetInt(Objecto,longoffset){returntheInternalUnsafe.getInt(o,offset);}反过来,最新的看起来实际上像旧的sun.misc.Unsafe,但现在这些方法用一些注释进行了注释:@HotSpotIntrinsicCandidatepublicnativevoidputObject(Objecto,longoffset

java - 为 Unsafe.putOrdered*() 的发布实现获取?

您认为在Java中实现发布/获取对的获取部分的最佳正确方法是什么?我正在尝试使用经典的发布/获取语义(没有StoreLoad并且没有跨线程的顺序一致性)对我的应用程序中的一些操作进行建模。有几种方法可以在JDK中实现大致相当于商店发布的效果。java.util.concurrent.Atomic*.lazySet()和底层sun.misc.Unsafe.putOrdered*()是最常被引用的方法。但是,没有明显的方法来实现加载获取。允许lazySet()的JDKAPI大多在内部使用volatile变量,因此它们的存储发布与易变加载配对。从理论上讲,volatile加载应该比加载获取更

java - Java 9 中不明确的内在行为

假设我有这段代码(我认为这真的无关紧要,但以防万一):publicclassAtomicJDK9{staticAtomicIntegerai=newAtomicInteger(0);publicstaticvoidmain(String[]args){intsum=0;for(inti=0;i下面是我调用它的方式(使用java-9):java-XX:+UnlockDiagnosticVMOptions-XX:-TieredCompilation-XX:+PrintIntrinsicsAtomicJDK9我想找出的是哪些方法被内部代码取代了。第一个被击中的(在Unsafe内部):@Hot

java - 使用 Unsafe.getUnsafe().throwException 抛出异常

我在java.lang.Class#newInstance0中发现了一些有趣的代码://Runconstructortry{returntmpConstructor.newInstance((Object[])null);}catch(InvocationTargetExceptione){Unsafe.getUnsafe().throwException(e.getTargetException());//Notreachedreturnnull;}查看Unsafe.getUnsafe().throwException语句。看起来一个已检查的异常是从一个没有声明要抛出的方法中抛出的!

java - 为什么 JNI 调用本地方法比 sun.misc.Unsafe 中的类似方法慢?

我正在开发一个类似于sun.misc.Unsafe但具有扩展内存管理的JNI实现。为什么来自sun.misc.Unsafe和我开发的库的本地方法的调用时间截然不同?一些数字:sun.misc.Unsafe.getInt(address)需要~1ns当我的类似方法需要~10ns两种实现方式大体相同,都沿用了OpenJDK的源码,只是通过指针返回变量。两者的注册方式相同。如何加速JNI调用?是什么让不安全性能如此特别?谢谢,尤里/ 最佳答案 如果您在Unsafe类中寻找native方法的来源,您会发现它不使用JNI实现。相反,不安全的方

java - 为什么 sun.misc.Unsafe 存在,如何在现实世界中使用它?

前几天我遇到了sun.misc.Unsafe包,并对它的功能感到惊讶。当然,这个类没有记录,但我想知道是否有充分的理由使用它。您可能会在哪些情况下需要使用它?在现实场景中如何使用它?此外,如果您确实需要它,这是否表明您的设计可能有问题?为什么Java甚至包含这个类? 最佳答案 例子虚拟机“内在化”。即CAS(Compare-And-Swap)用于Lock-FreeHashTables例如:sun.misc.Unsafe.compareAndSwapInt它可以对包含CAS特殊指令的native代码进行真正的JNI调用在这里阅读更多关