final变量和普通变量的区别

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变量值的情况下,编译器才会优化

发布了58 篇原创文章 · 获赞 3 · 访问量 5714

猜你喜欢

转载自blog.csdn.net/hc1428090104/article/details/99218541
今日推荐