美文网首页
深入理解jvm(二)常量

深入理解jvm(二)常量

作者: 付家明 | 来源:发表于2018-09-14 15:58 被阅读0次

    常量在编译阶段会存入到调用这个常量的方法所在的类的常量池中,本质上,调用类并没有直接引用到定义常量的类,因此并不会触发定义常量的类的初始化。示例代码:

    示例代码-str没加final

    此时初始化了MyParent2.

    运行结果-str没加final 示例代码-加上final 运行结果-加上final

    注意:这里指的是将常量存放到了MyTest2的常量池中,之后MyTest2与MyParent2就没有任何关系了。甚至,我们可以将MyParent2的class文件删除。

    这里还需区分一下static+final(静态常量)和final的区别:
    static+final

    静态常量,编译期常量,编译时就确定值。(Java代码执行顺序,先编译为class文件,在用虚拟机加载class文件执行)

    放于方法区中的静态常量池。

    在编译阶段存入调用类的常量池中

    如果调用此常量的类不是定义常量的类,那么不会初始化定义常量的类,因为在编译阶段通过常量传播优化,已经将常量存到调用类的常量池中了

    final

    常量,类加载时确定或者更靠后。

    当用final作用于类的成员变量时,成员变量(注意是类的成员变量,局部变量只需要保证在使用之前被初始化赋值即可)必须在定义时或者构造器中进行初始化赋值

    对于一个final变量,如果是基本数据类型的变量,则其数值一旦在初始化之后便不能更改;

    如果是引用类型的变量,则在对其初始化之后便不能再让其指向另一个对象。但是它指向的对象的内容是可变的。

    还有一种情况,即一个常量值编译期间不能确定,示例如下:

    相关文章

      网友评论

          本文标题:深入理解jvm(二)常量

          本文链接:https://www.haomeiwen.com/subject/jguygftx.html