我完成了一个Java库,我用它来替换{{1}}包(即,在普通JVM库之前将它添加到引导类加载器)。在包中,它动态生成方法句柄的字节码。如果您有关于此课程的任何信息,谢谢!
目前,这个软件包在运行JRuby测试用例时运行正常,但是当我尝试使用Nashorn(用于JavaScript语言的Java版本)进行测试时它失败了。错误消息是:
java.lang.invoke
对于异常,我找不到来自nashorn包的任何类JO28P0。我无法通过谷歌获取此课程的任何信息。
这里的JS来自octane基准测试,我在其中评论除前两种情况之外的所有测试:
java.lang.NoClassDefFoundError: jdk.nashorn.internal.scripts.JO28P0
at java.lang.invoke.DYNGuardWithTestHandle702.0000000051119BF0.<clinit>(Unknown Source)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:88)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:57)
at java.lang.reflect.Constructor.newInstance(Constructor.java:437)
at code.jit.asm.plugins.MethodHandlePlugin.initObject(MethodHandlePlugin.java:208)
at code.jit.asm.backplane.ClassContext.createTransformedObject(ClassContext.java:359)
at code.jit.asm.services.BytecodeGenerator$6.action(BytecodeGenerator.java:211)
at code.jit.asm.services.BytecodeGenerator.run(BytecodeGenerator.java:325)
at code.jit.asm.services.BytecodeGenerator.generate(BytecodeGenerator.java:291)
at code.jit.asm.services.BytecodeGenerator.startGenerating(BytecodeGenerator.java:257)
at code.jit.asm.services.TaskRepositoryService.put(TaskRepositoryService.java:48)
at code.jit.asm.services.BytecodeGenerator.generate(BytecodeGenerator.java:251)
at code.jit.asm.services.BytecodeGenerator.generate(BytecodeGenerator.java:247)
at java.lang.invoke.CallSite.jitMethodHandle(CallSite.java:125)
at java.lang.invoke.MutableCallSite.setTarget(MutableCallSite.java:116)
at jdk.internal.dynalink.ChainedCallSite.relinkInternal(ChainedCallSite.java:209)
at jdk.internal.dynalink.ChainedCallSite.relink(ChainedCallSite.java:161)
at jdk.nashorn.internal.runtime.linker.LinkerCallSite.relink(LinkerCallSite.java:154)
at jdk.internal.dynalink.DynamicLinker.relink(DynamicLinker.java:297)
at java.lang.invoke.DirectHandle.invokeExact_thunkArchetype_L(DirectHandle.java:291)
at java.lang.invoke.DYNFoldNonvoidHandle699.00000000525AABE0.inlinedMethod(Unknown Source)
at java.lang.invoke.MutableCallSiteDynamicInvokerHandle.invokeExact_thunkArchetype_X(MutableCallSiteDynamicInvokerHandle.java:56)
at jdk.nashorn.internal.scripts.Script$4$richards.:program(file:/C:/sxu/project/octane/richards.js:515)
at jdk.nashorn.internal.runtime.ScriptFunctionData.invoke(ScriptFunctionData.java:635)
at jdk.nashorn.internal.runtime.ScriptFunction.invoke(ScriptFunction.java:506)
at jdk.nashorn.internal.runtime.ScriptRuntime.apply(ScriptRuntime.java:405)
at jdk.nashorn.internal.runtime.Context.evaluateSource(Context.java:1236)
at jdk.nashorn.internal.runtime.Context.load(Context.java:849)
at jdk.nashorn.internal.objects.Global.load(Global.java:1544)
启动案例的主要Java代码是:
C:\\sxu\\project\\octane\\run.js
var base_dir = 'C:\\sxu\\project\\octane\\';
load(base_dir + 'base.js');
load(base_dir + 'richards.js');/*
load(base_dir + 'deltablue.js');
...
load(base_dir + 'typescript-compiler.js'); */
一个VM参数是public static void runOctane(String[] args) {
NashornScriptEngine nashorn = (NashornScriptEngine) new ScriptEngineManager().getEngineByName("nashorn");
CompiledScript scr = nashorn.compile(new String(Files.readAllBytes(
Paths.get("C:\\sxu\\project\\octane\\run.js"))));
scr.eval();
}
。如果这个论点是真的,那么将去我的图书馆。否则,我的库将无法生效。
如果-Djit_bytecode=true
为false,则异常消失。
更新:
我的代码发出动态字节码,其中包含符号jit_bytecode
。当我尝试使用JO28P0
时抛出了异常。那么如何使用Structure ClassLoader以使UNSAFE.defineAnonymousClass()
成功?