java编译期常量 static final

原文地址:http://www.cnblogs.com/ningvsban/p/3591610.html

编译器常量的特点就是:它的值在编译期就可以确定。比如:

  final int i = 5;

  再傻的编译器也能在编译时看出它的值是5,不需要到运行时。对于运行时常量,它的值虽然在运行时初始化后不再发生变化,但问题就在于它的初始值要到运行时才能确定。 

  比如:

  Random rand = new Random(47);

  final int i4 = rand.nextInt(20);

  虽然i4的值在定义并初始化后不会再发生变化(除非你使用一些不符合标准的小技巧),但再聪明的编译器也无法在编译时确定它的值呀。

   为了更清楚的理解编译器常量的概念,我们引入【常量折叠】的概念:在编译器里进行语法分析的时候,将常量表达式计算求值,并用求得的值来替换表达式,放入常量表,可以算作一种编译优化。

  对于编译期常量,编译器常常在编译时就可以折叠开。而对于运行期常量,编译期无法折叠,编译器能做的,只是对所有可能修改它的动作报错。

案例1:

复制代码
package testPage;

class InitalizedClass {
    static {
        System.out.println("You have initalized InitalizedClass!");
    }
    public static int inititalize_varible = 1;

}

public class TestInitializeClass {
    
    public static void main(String[] args) {
        System.out.println(InitalizedClass.inititalize_varible);
    }
    /**
     * 输出结果为:
     * You have initalized InitalizedClass!
     * 1
     */

}
复制代码

案例2:

复制代码
package testPage;

class InitalizedClass {
    static {
        System.out.println("You have initalized InitalizedClass!");
    }
       //和上面的例子唯一的差异就是此处的变量INITIALIZED_VARIBLE被声明为final
    public final static int INITIALIZED_VARIBLE = 1;

}

public class TestInitializeClass {
    public static void main(String[] args) {
        System.out.println(InitalizedClass.INITIALIZED_VARIBLE);
    }
    /**
     * 输出结果为:
     * 1
     */
}
复制代码

  为什么两个例子执行结果不一样,原因是第二个例子中的INITIALIZED_VARIBLE为编译期常量,它不会导致类的初始化。


  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值