JAVA在编译过程会对代码进行优化,如果某一行代码永远不可能被执行到,
这行代码不会被编译到字节码文件中去。
如下面的例子,flag是一个可以在编译阶段就可以确定的值,
javac编译的时候不会把System.out.println编译到字节码文件中。
javap verbose可以看到 test 方法中没有和System.out.println相对应的指令。
public final static boolean flag = true;
通过javap verbose可以看到字节码中, test方法中有和System.out.println相对应的指令。
完全不出现在字节码中。不过调整log输出级别需要从新编译源代码。
这行代码不会被编译到字节码文件中去。
如下面的例子,flag是一个可以在编译阶段就可以确定的值,
javac编译的时候不会把System.out.println编译到字节码文件中。
public class T {
public final static boolean flag = false;
public void test(){
if(flag){
System.out.println("print this line");
}
}
}
javap verbose可以看到 test 方法中没有和System.out.println相对应的指令。
public void test();
Code:
Stack=0, Locals=1, Args_size=1
0: return
LineNumberTable:
line 10: 0
LocalVariableTable:
Start Length Slot Name Signature
0 1 0 this LT;
}
如果将flag改为true
public final static boolean flag = true;
通过javap verbose可以看到字节码中, test方法中有和System.out.println相对应的指令。
public void test();
Code:
Stack=2, Locals=1, Args_size=1
0: getstatic #19; //Field java/lang/System.out:Ljava/io/PrintStream;
3: ldc #25; //String print this line
5: invokevirtual #27; //Method java/io/PrintStream.println:(Ljava/lang/String;)V
8: return
LineNumberTable:
line 8: 0
line 10: 8
LocalVariableTable:
Start Length Slot Name Signature
0 9 0 this LT;
}
这种特性可以利用到log输出的场景,通过一个编译时常量控制某些log输出的代码
完全不出现在字节码中。不过调整log输出级别需要从新编译源代码。