点击上方“Java基基”,选择“设为星标”
做积极的人,而不是积极废人!
每天 14:00 更新文章,每天掉亿点点头发...
源码精品专栏
来源:blog.csdn.net/weixin_38111957/
假如有一天,你要找工作,等到了面试邀请,来到了面试公司,做完了笔试题,迎来了面试官。
![d0480dbaab70ae228d44a4ddaac53b71.png](https://img-blog.csdnimg.cn/img_convert/d0480dbaab70ae228d44a4ddaac53b71.png)
面试官的第一个问题确是:你如何用一段代码证明在JVM加载类是懒加载模式?
![11e74839bb950caa54afa582b2bdce64.png](https://img-blog.csdnimg.cn/img_convert/11e74839bb950caa54afa582b2bdce64.png)
来来来,都坐下,先看看这段代码,思考一下结果。
public class SuperClass {
static {
System.out.println("SuperClass init");
}
public static int value = 10;
}
class SubClass extends SuperClass {
static {
System.out.println("SubClass init");
}
}
class TestClass {
public static void main(String[] args) {
System.out.println(SubClass.value);
}
}
上述代码,只会输出:
SuperClass init
10
而不会输出SubClass init
,对于静态字段,只有直接定义这个字段的类才会被初始化,因此通过其子类来引用父类中定义的静态字段,只会触发父类的初始化,而不会初始化子类。
所以就能证明JVM加载类是懒加载模式, 我们再来看看其他的情况。
public class NotInitialization {
public static void main(String[] args) {
// SuperClass 引用上面代码的类
SuperClass[] superClasses = new SuperClass[10];
}
}
上面这段代码,创建了一个引用类型的数组,请问SuperClass会被初始化么?
“噢,这里都直接new了,肯定会被初始化呀~~”
![89485940934d8e5e2e0b0d82aa4b446d.png](https://img-blog.csdnimg.cn/img_convert/89485940934d8e5e2e0b0d82aa4b446d.png)
答案是不会、不会、不会~~
再来看最后一段代码,想想ConstClass中的stataic静态代码块会被执行么?
public class ConstClass {
static {
System.out.println("ConstClass init");
}
public static final String HELLOWORLD = "hello world";
}
class ConstTest {
public static void main(String[] args) {
System.out.println(ConstClass.HELLOWORLD);
}
}
运行结果也没有输出“ConstClass init”,这是因为虽然在Java代码中引用了ConstClass中的常量,但是在编译阶段,hello world 已经被存储到NotInitialization类的常量池中去了,所以这里HELLOWORLD常量的引用就指向NotIntialization类的常量池了。
欢迎加入我的知识星球,一起探讨架构,交流源码。加入方式,长按下方二维码噢:
已在知识星球更新源码解析如下:
最近更新《芋道 SpringBoot 2.X 入门》系列,已经 101 余篇,覆盖了 MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。
提供近 3W 行代码的 SpringBoot 示例,以及超 6W 行代码的电商微服务项目。
获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。
文章有帮助的话,在看,转发吧。
谢谢支持哟 (*^__^*)