gpt4 book ai didi

java - 为什么 javac 会为两个看似非常相似的结构生成不同的字节码?

转载 作者:塔克拉玛干 更新时间:2023-11-01 22:26:05 27 4
gpt4 key购买 nike

考虑非常简单的人为示例代码:

 public class TestJavap {
public static void main(String[] args) {
int a = 3;
int b = 7;
}
}

javap 产生这个:

 public static void main(java.lang.String[]);
Code:
0: iconst_3
1: istore_1
2: bipush 7
4: istore_2
5: return
  1. 为什么编译器为非常相似的字段 ab 生成不同的字节码。两者都是用常量文字初始化的整数类型。

    对于 a,它通过 iconst_3 从池中获取常量,然后通过 istore_1 将其存储在变量中,而对于 b,它使用 a完全不同的机制(bipushistore 的组合)。

最佳答案

why the compiler is producing different byte code for very similar fields a and b

来自整数-1 - 5 iconst_x(x是0-5之间的数字)它已经是一个常量字节码。

iconst_m1   02      → -1    load the int value -1 onto the stack
iconst_0 03 → 0 load the int value 0 onto the stack
iconst_1 04 → 1 load the int value 1 onto the stack
iconst_2 05 → 2 load the int value 2 onto the stack
iconst_3 06 → 3 load the int value 3 onto the stack
iconst_4 07 → 4 load the int value 4 onto the stack
iconst_5 08 → 5 load the int value 5 onto the stack

因此,如果数字不是 iconst_ 字节码的常量值,那么它将使用 bipush 字节码。

有关 list of java bytecode 的更多信息&& JVMS

关于java - 为什么 javac 会为两个看似非常相似的结构生成不同的字节码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25167974/

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