⭐⭐⭐ Spring Boot 项目实战 ⭐⭐⭐ Spring Cloud 项目实战
《Dubbo 实现原理与源码解析 —— 精品合集》 《Netty 实现原理与源码解析 —— 精品合集》
《Spring 实现原理与源码解析 —— 精品合集》 《MyBatis 实现原理与源码解析 —— 精品合集》
《Spring MVC 实现原理与源码解析 —— 精品合集》 《数据库实体设计合集》
《Spring Boot 实现原理与源码解析 —— 精品合集》 《Java 面试题 + Java 学习指南》

摘要: 原创出处 blog.csdn.net/weixin_38111957/article/details/108222172 「IT贱男」欢迎转载,保留摘要,谢谢!


🙂🙂🙂关注**微信公众号:【芋道源码】**有福利:

  1. RocketMQ / MyCAT / Sharding-JDBC 所有源码分析文章列表
  2. RocketMQ / MyCAT / Sharding-JDBC 中文注释源码 GitHub 地址
  3. 您对于源码的疑问每条留言将得到认真回复。甚至不知道如何读源码也可以请教噢
  4. 新的源码解析文章实时收到通知。每周更新一篇左右
  5. 认真的源码交流微信群。

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

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

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

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了,肯定会被初始化呀~~”

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

再来看最后一段代码,想想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类的常量池了。

文章目录