JVM 字节码中的 NOP 用于什么?
Java虚拟机的操作码在今天的JVM中是否有任何实际用途?如果是这样,在哪些情况下会在字节码中生成 s?NOP
NOP
我甚至有兴趣看到一个Java代码的例子,它编译成带有s的字节码。NOP
更新
BCEL的MethodGen类说:
生成代码时,可能需要插入 NOP 操作。
我猜其他字节码生成库也在同一条船上,正如在接受的答案中指出的那样。
Java虚拟机的操作码在今天的JVM中是否有任何实际用途?如果是这样,在哪些情况下会在字节码中生成 s?NOP
NOP
我甚至有兴趣看到一个Java代码的例子,它编译成带有s的字节码。NOP
更新
BCEL的MethodGen类说:
生成代码时,可能需要插入 NOP 操作。
我猜其他字节码生成库也在同一条船上,正如在接受的答案中指出的那样。
一些字节码用例用于由Apache BCEL,ASM,FindBugs,PMD等工具执行的文件转换,优化和静态分析。Apache BCEL 手册介绍了 用于分析和优化目的的一些用途。NOP
class
NOP
JVM 可以使用字节码进行 JIT 优化,以确保处于同步安全点的代码块正确对齐,以避免错误共享。NOP
至于使用包含字节码的JDK编译器编译的一些示例代码,这是一个有趣的挑战。但是,我怀疑编译器会生成任何包含字节码的文件,因为字节码指令流只是单字节对齐的
。我很想看到这样的例子,但我自己也想不出任何例子。javac
NOP
class
NOP
以下是我一直在研究的一些代码中的一个示例,其中nop指令被放置在字节代码中(如Eclipse的Bytecode Visualizer所查看的那样)
原始代码
public abstract class Wrapper<T extends Wrapper<T,E>,E>
implements Supplier<Optional<E>>, Consumer<E>
{
/** The wrapped object. */
protected Optional<E> inner;
/*
* (non-Javadoc)
* @see java.lang.Object#equals(java.lang.Object)
*/
/**
* A basic equals method that will compare the wrapped object to
* whatever you throw at it, whether it is wrapped or not.
*/
@Override
public boolean equals(final Object that)
{
return this==that
||LambdaUtils.castAndMap(that,Wrapper.class,afterCast
-> inner.equals(afterCast.inner))
.orElseGet(()
-> LambdaUtils.castAndMap(that,Optional.class,afterCast
-> inner.equals(afterCast))
.orElseGet(()
-> Optional.ofNullable(that).map(thatobj
-> that.equals(inner.get()))
.orElseGet(()
-> false)));
}
}
equals(Object) 方法的已转换字节代码
public boolean equals(java.lang.Object arg0) {
/* L27 */
0 aload_0; /* this */
1 aload_1; /* that */
2 if_acmpeq 36;
/* L28 */
5 aload_1; /* that */
6 ldc 1;
8 aload_0; /* this */
9 invokedynamic 29; /* java.util.function.Function apply(ext.cat.wcutils.collections.Wrapper arg0) */
12 nop;
13 nop;
14 invokestatic 30; /* java.util.Optional ext.cat.wcutils.util.LambdaUtils.castAndMap(java.lang.Object arg0, java.lang.Class arg1, java.util.function.Function arg2) */
/* L30 */
17 aload_0; /* this */
18 aload_1; /* that */
19 invokedynamic 39; /* java.util.function.Supplier get(ext.cat.wcutils.collections.Wrapper arg0, java.lang.Object arg1) */
22 nop;
23 nop;
24 invokevirtual 40; /* java.lang.Object orElseGet(java.util.function.Supplier arg0) */
27 checkcast 46; /* java.lang.Boolean */
30 invokevirtual 48; /* boolean booleanValue() */
/* L37 */
33 ifne 5;
/* L27 */
36 iconst_0;
37 ireturn;
38 iconst_1;
39 ireturn;
}
我不知道为什么要插入这些内容。我只是希望它们不会对性能产生不利影响。