面试官:如何用一段代码证明JVM加载类是懒加载模式

面试官提问,如何用一段代码证明JVM加载类是懒加载模式?

假如有一天,你要找工作,等到了面试邀请,来到了面试公司,做完了笔试题,迎来了面试官。

面试官的第一个问题确是:你如何用一段代码证明在JVM加载类是懒加载模式?

image.png

来来来,都坐下,先看看这段代码,思考一下结果。

publicclassSuperClass{

static{

System.out.println( “SuperClass init”);

}

publicstaticintvalue = 10;

}

classSubClassextendsSuperClass{

static{

System.out.println( “SubClass init”);

}

}

classTestClass{

publicstaticvoidmain(String[] args){

System.out.println(SubClass.value);

}

}

上述代码,只会输出:

SuperClass init

10

而不会输出 SubClass init ,对于静态字段,只有直接定义这个字段的类才会被初始化,因此通过其子类来引用父类中定义的静态字段,只会触发父类的初始化,而不会初始化子类。

所以就能证明JVM加载类是懒加载模式, 我们再来看看其他的情况。

publicclassNotInitialization{

publicstaticvoidmain(String[] args){

// SuperClass 引用上面代码的类

SuperClass[] superClasses = newSuperClass[ 10];

}

}

上面这段代码,创建了一个引用类型的数组,请问SuperClass会被初始化么?

“噢,这里都直接new了,肯定会被初始化呀~~”

image.png

答案是不会、不会、不会~~

再来看最后一段代码,想想ConstClass中的stataic静态代码块会被执行么?

publicclassConstClass{

static{

System.out.println( “ConstClass init”);

}

publicstaticfinalString HELLOWORLD = “hello world”;

}

classConstTest{

publicstaticvoidmain(String[] args){

System.out.println(ConstClass.HELLOWORLD);

}

}

运行结果也没有输出“ConstClass init”,这是因为虽然在Java代码中引用了ConstClass中的常量,但是在编译阶段,hello world 已经被存储到NotInitialization类的常量池中去了,所以这里HELLOWORLD常量的引用就指向NotIntialization类的常量池了。

· END ·

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值