java 字节码 - 没有 ipush 指令

标签 java jvm bytecode

作为我学校项目的一部分,我需要深入研究 Java 字节码。我开始编写简单的程序并使用 javap 实用程序查看生成的字节码,我有一个关于 *ipush 指令的问题。

当我查看这段代码的字节码时:

public class Main{
  public static void main(String []args){
    int a;
    a=5;
    a=a+32765;
  }
}

我得到了

public class Main
  SourceFile: "Main.java"
  minor version: 0
  major version: 51
  flags: ACC_PUBLIC, ACC_SUPER
Constant pool:
  #1 = Methodref          #3.#12         //  java/lang/Object."<init>":()V
  #2 = Class              #13            //  Main
  #3 = Class              #14            //  java/lang/Object
  #4 = Utf8               <init>
  #5 = Utf8               ()V
  #6 = Utf8               Code
  #7 = Utf8               LineNumberTable
  #8 = Utf8               main
  #9 = Utf8               ([Ljava/lang/String;)V
  #10 = Utf8               SourceFile
  #11 = Utf8               Main.java
  #12 = NameAndType        #4:#5          //  "<init>":()V
  #13 = Utf8               Main
  #14 = Utf8               java/lang/Object
{
  public Main();
flags: ACC_PUBLIC
Code:
  stack=1, locals=1, args_size=1
    0: aload_0       
    1: invokespecial #1                  // Method java/lang/Object."<init>":()V
    4: return        
  LineNumberTable:
    line 1: 0

  public static void main(java.lang.String[]);
flags: ACC_PUBLIC, ACC_STATIC
Code:
  stack=2, locals=2, args_size=1
    0: iconst_5      
    1: istore_1      
    2: iload_1       
    3: sipush        32765
    6: iadd          
    7: istore_1      
    8: return        
  LineNumberTable:
    line 4: 0
    line 5: 2
    line 6: 8
}

当我将 32765 换成 32769 时,我得到的是不在空头范围内的

public class Main
  SourceFile: "Main.java"
  minor version: 0
  major version: 51
  flags: ACC_PUBLIC, ACC_SUPER
Constant pool:
  #1 = Methodref          #4.#13         //  java/lang/Object."<init>":()V
  #2 = Integer            32769
  #3 = Class              #14            //  Main
  #4 = Class              #15            //  java/lang/Object
  #5 = Utf8               <init>
  #6 = Utf8               ()V
  #7 = Utf8               Code
  #8 = Utf8               LineNumberTable
  #9 = Utf8               main
  #10 = Utf8               ([Ljava/lang/String;)V
  #11 = Utf8               SourceFile
  #12 = Utf8               Main.java
  #13 = NameAndType        #5:#6          //  "<init>":()V
  #14 = Utf8               Main
  #15 = Utf8               java/lang/Object
{
  public Main();
flags: ACC_PUBLIC
Code:
  stack=1, locals=1, args_size=1
    0: aload_0       
    1: invokespecial #1                  // Method java/lang/Object."<init>":()V
    4: return        
  LineNumberTable:
    line 1: 0

  public static void main(java.lang.String[]);
flags: ACC_PUBLIC, ACC_STATIC
Code:
  stack=2, locals=2, args_size=1
    0: iconst_5      
    1: istore_1      
    2: iload_1       
    3: ldc           #2                  // int 32769
    5: iadd          
    6: istore_1      
    7: return        
  LineNumberTable:
    line 4: 0
    line 5: 2
    line 6: 7
}

所以现在数字存储在常量池中。我知道没有指令 ipush 可以用来将整数常量压入堆栈,但我想知道为什么没有这样的指令?

最佳答案

基于简单的 CISC 设计,他们试图使每条指令尽可能短(以字节为单位)使用 32 位或 64 位常量的指令更容易/更短地引用常量表。

关于java 字节码 - 没有 ipush 指令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16881769/

相关文章:

java - JVM 是 VM 的一种形式吗?

java - 输出-1在循环中变成斜杠

java - 将动态参数传递给注释

r - 编译后的 R 代码实际上比启用 JIT 的纯 R 慢

java - 使用 Jackson Objectmapper 将整数列表从 json 反序列化为 java

spring - 使用 Java 将 Outlook 电子邮件以 .MSG 格式存储到磁盘

java - ASM之前看一下maxStack指令吗?

java - 为什么代码不读取 nextLine()?

用于仿真的 Java Swing

java - 为什么 ASM 不调用我的 `` VisitCode``?