这行代码不会被编译到字节码文件中去。
如下面的例子,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输出级别需要从新编译源代码。