我在下面提供了一些编译类的代码。
public class PlusOperator {
public static void main(String[] args) {
int a=10;
int b=20;
int c =a+b;
String s1 = 1+3+"f";
String s2 = "f"+1+2;
String s3 = (1+3)+"f";
String s4 = "f"+(1+3);
}
}
使用Java 1.6编译的类
// Compiled from PlusOperator.java (version 1.6 : 50.0, super bit)
public class question.PlusOperator {
// Method descriptor #6 ()V
// Stack: 1, Locals: 1
public PlusOperator();
0 aload_0 [this]
1 invokespecial java.lang.Object() [8]
4 return
Line numbers:
[pc: 0, line: 3]
Local variable table:
[pc: 0, pc: 5] local: this index: 0 type: question.PlusOperator
// Method descriptor #15 ([Ljava/lang/String;)V
// Stack: 2, Locals: 8
public static void main(java.lang.String[] args);
0 bipush 10
2 istore_1 [a]
3 bipush 20
5 istore_2 [b]
6 iload_1 [a]
7 iload_2 [b]
8 iadd
9 istore_3 [c]
10 ldc <String "4f"> [16]
12 astore 4 [s1]
14 ldc <String "f12"> [18]
16 astore 5 [s2]
18 ldc <String "4f"> [16]
20 astore 6 [s3]
22 ldc <String "f4"> [20]
24 astore 7 [s4]
26 return
Line numbers:
[pc: 0, line: 7]
[pc: 3, line: 8]
[pc: 6, line: 9]
[pc: 10, line: 11]
[pc: 14, line: 12]
[pc: 18, line: 13]
[pc: 22, line: 14]
[pc: 26, line: 16]
Local variable table:
[pc: 0, pc: 27] local: args index: 0 type: java.lang.String[]
[pc: 3, pc: 27] local: a index: 1 type: int
[pc: 6, pc: 27] local: b index: 2 type: int
[pc: 10, pc: 27] local: c index: 3 type: int
[pc: 14, pc: 27] local: s1 index: 4 type: java.lang.String
[pc: 18, pc: 27] local: s2 index: 5 type: java.lang.String
[pc: 22, pc: 27] local: s3 index: 6 type: java.lang.String
[pc: 26, pc: 27] local: s4 index: 7 type: java.lang.String
}
我的问题:
答案 0 :(得分:5)
a
和b
是变量 - 它们的值仅在运行时 1 中已知。但是,1
,f
和3
是常量,因此编译器足够聪明,可以计算结果并将其包含在字节码中。因此,3
+ f
等表达式会自动编译为常量3f
。
这与类型为int
或String
的操作数无关。尝试使用String
s:
String str = a + b;
您将在已编译的代码中看到对StringBuilder#append(String)
的调用。
1 例外情况是变量声明为final
时,所以在以下代码中:
final int a=10;
final int b=20;
int c = a + b;
c
直接在字节码中分配值30
:
bipush 10
istore_1
bipush 20
istore_2
bipush 30
istore_3
答案 1 :(得分:-1)
您正在深入了解编译器的工作方式。它正在解析您的代码,然后可行将其转换为字节码。如果&#34; +&#34;运算符在字符串中使用,如果在二进制表达式中使用,则它将以单向方式运行,然后它将另作。操作员超载。
&#34; +&#34;运算符过载。
这是在编译器中完成的代码优化。