上一篇文章我们说到了static关键字,可是本人觉得还不是很完整,现在补一篇文章举例说明static关键字对jvm类加载器的影响,这篇文章讲解了jvm对关键字static进行的优化。原创不易,转载请注明出处。
1.当子类主动访问的时候,会引起其父类的初始化
举一个例子:
/**
* @author yangwuyi
*/
class Father{
static int age ;
static {
System.out.println("Father's static CodeBlock");
age = 100;
}
}
class Son extends Father{
static int high ;
static {
System.out.println("Son's static CodeBlock");
high = 176;
}
}
public class StaticEffic {
@Test
public void test(){
System.out.println(Son.high);
}
}
运行的结果是:
因为直接访问Son.high,会先初始化Father类,然后初始化Son类。
2.子类直接访问父类的变量,只会初始化父类而不会初始化子类
举个例子
但是如果通过子类直接访问父类的变量,jvm只会初始化父类而不会初始化子类
import org.junit.Test;
/**
* @author yangwuyi
*/
class Father{
static int age ;
static {
System.out.println("Father's static CodeBlock");
age = 100;
}
}
class Son extends Father{
static int high ;
// static int age;
static {
System.out.println("Son's static CodeBlock");
high = 176;
age = 55;
}
}
public class StaticEffic {
@Test
public void test(){
System.out.println(Son.age);
System.out.println(Son.high);
System.out.println(Father.age);
}
}
我们会发现这一次运行的效果是:
这里就很明显了,因为当我们调用Son.age的时候,static age在内存中只有一份,所以jvm会认为当我们执行Son.age的时候,必须要初始化Father类,这样才可以访问到age变量,这个时候Father类完成初始化Static代码块执行完毕。但是因为Son和Father的Static int age在内存中只有一份,既然只有一份那就不初始化Son了,但是当我们调用Son.high的时候,jvm这个时候才会初始化Son类,输出“Son’s static CodeBlock”;然后对age变量赋值,因为Father和Son的Static int age在内存中只有一份,所以当我们输出Father.age的时候,一样是55。这就是JVM对Static的优化。