疯狂java笔记:关于final修饰符

public class FinalStaticTest { final static String str1; final static String str2 = "Good!"; static{ str1 = "Good!"; } public static void main(String[] args) { System.out.println(str1 + str2 == "Good!Good!"); System.out.println(str2 + str2 == "Good!Good!"); } }

 

结果:

fasle

true

 

原因:

1.final修饰的变量会定义成为常量,即一旦定义并赋值好,其值就不可改变。

2.在编译器编译期间就确定final变量的值,在实际使用final变量时就直接使用值,而不是变量符号。类似c语言的“宏替换”。

3.上述的“宏替换”是有条件的,只有在定义final变量时直接赋值才能告知编译器在编译期间直接将源码中的final变量符号替换成其实际值。

4.编译器会对final的变量的操作进行优化,如上源码中final变量的相加,编译器会自动生成一个等于其结果的常量。

 

public class FinalVarInnerTest { public static void main(String[] args) { final String v = "I come from the method of main"; new Thread( new Runnable(){ public void run(){ System.out.println(v); } } ).start(); } }

 

关于内部类使用的局部变量必须是final修饰的:

      局部变量应该只能在该方法的生命周期内有效,而不应该在方法结束后仍然有效。final修饰的局部变量则改变这种规则,通过final修饰的局部变量可以存活在内部类调用方法的生命周期以内,书中定义为“隐式的闭包”。final修饰符只是扩大读取局部变量的范围,而没有扩大修改该变量的范围,因为final变量是不可变的。

你可能感兴趣的:(java,thread,优化,String,Class,编译器)