static+final
- 静态常量,编译期常量,编译时就确定值。(Java代码执行顺序,先编译为class文件,在用虚拟机加载class文件执行)
- 放于方法区中的静态常量池。
- 在编译阶段存入调用类的常量池中
- 如果调用此常量的类不是定义常量的类,那么不会初始化定义常量的类,因为在编译阶段通过常量传播优化,已经将常量存到调用类的常量池中了
class ConstC{
static{
System.out.println("ConstC init!");
}
public ConstC(){
System.out.println("ConstC ");
}
public static final String HELLO = "hello world!";
}
public class NotInit {
public static void main(String[] args) {
//经过编译优化,静态常量HELLO已经存到NotInit类自身常量池中,不会加载ConstC
System.out.println(ConstC.HELLO);
}
}
//输出:hello world!
final
- 常量,类加载时确定或者更靠后。
- 当用final作用于类的成员变量时,成员变量(注意是类的成员变量,局部变量只需要保证在使用之前被初始化赋值即可)必须在定义时或者构造器中进行初始化赋值
- 对于一个final变量,如果是基本数据类型的变量,则其数值一旦在初始化之后便不能更改;
- 如果是引用类型的变量,则在对其初始化之后便不能再让其指向另一个对象。但是它指向的对象的内容是可变的
本文深入探讨了Java中`static`和`final`关键字的使用。`static`修饰的静态常量在编译期间即确定值,存储于方法区的静态常量池,即使在非初始化类中调用也不会触发其初始化。而`final`变量可以在类加载时或之后确定,对于基本类型变量其值不可变,引用类型变量则指针不可变但对象内容可变。理解这些概念有助于优化代码并避免不必要的类初始化。

被折叠的 条评论
为什么被折叠?



