public class Test{
public static void main(String[] args){
String a = "handao";
final String b = "han";
String c = "han";
String d = b+"dao";
String e = c+"dao";
System.out.println(a==d) //true
System.out.println(a==e) //false
}
}
这里面就是final变量和普通变量的区别了
当final变量时基本数据类型以及String类型时,如果在编译期间能知道他的确切值
则编译器会把它当作编译器常量使用
也即是说,在用到该final变量的地方,就相当于直接访问的这个常量,不需要在运行时确定
因此上面的代码中
由于变量b被final修饰,因此会被当做编译器常量
所以在使用到b的地方会直接将变量b体会为他的值
而对于变量d的访问却需要在运行时通过链接进行
不过注意:只有在编译期间就能确切知道final变量值的情况下,编译器才会优化