class初始化过程

2020-08-12  本文已影响0人  南园故剑00

1. JVM 类加载机制分为五个部分:加载、验证、准备、解析、初始化

  1. 加载:加载时类加载过程中的一个阶段,这个阶段会在内存中生成一个代表这个类的class对象,作为方法区这个类的各种数据的入口。
    这里不一定非得从一个class文件获取,这里即可以从ZIP包中获取(比如jar包和war包中读取),也可以在运行时计算生成(动态代理),
    也可以由其他文件生成(比如将jsp文件转换成对应的class类)

  2. 验证:确保class文件的字节流中包含的信息是否符合当前虚拟机的要求,并不会危害虚拟机自身的安全

  3. 准备:正式为类变量分配内存并设置类变量的初始值阶段,即在方法区中分配这些变量所使用的内存空间。

  4. 解析阶段:指虚拟机将常量池中的符号引用替换为直接引用的过程。

  1. 初始化:初始化是类加载最后一个阶段,前面的类加载阶段后,除了在加载阶段可以自定义类加载器外,其他造作都由JVM主导。
    到了初始化阶段,才开始真正执行类中定义的java程序代码。
  1. 通过子类引用父类的静态字段,只会触发父类的初始化,而不会触发子类的初始化。
  2. 定义对象数组,不会触发该类的初始化。
  3. 常量在编译期间会存入调用类的常量池中,本质上并没有直接引用定义常量的类,不会触
    发定义常量所在的类。
  4. 通过类名获取 Class 对象,不会触发类的初始化。
  5. 通过 Class.forName 加载指定类时,如果指定参数 initialize 为 false 时,也不会触发类初
    始化,其实这个参数是告诉虚拟机,是否要对类进行初始化。
  6. 通过 ClassLoader 默认的 loadClass 方法,也不会触发初始化动作。

2. 类加载器:把加载动作放在JVM外部实现,以便让应用程序决定如何获取所需的类:

  1. 启动类加载器:bootstrap classLoader
    负责加载JAVA_HOME\lib目录中的,或通过-Xbootclasspath参数指定路径中的,且被虚拟机认可的类

  2. 扩展类加载器:extension classLoader
    负责加载JAVA_HOME\lib\ext目录中的,或通过java.ext.dirs系统变量指定路径中的类库。

  3. 应用程序类加载器:Application classLoader
    负责加载用户路径classpath上的类库

  4. jvm通过双亲委派模型进行类的加载,也可以通过继承classLoader实现自定义的类加载器

  1. 双亲委派:
    当一个类收到了类加载的请求,他首先不会尝试自己去加载这个类,而是把这个请求委派给父类去完成,每一个层次类加载器都是如此。
    因此所有的加载请求都应该传送到启动类加载器中,只有当父类加载器反馈自己无法完成这请求时(在他的加载路径下没有找到所需加载的class),
    子类加载器才会尝试自己去加载。

采用双亲委派模型的一个好处是比如加载位于rt.jar包中的类object,不管是哪个加载器加载这个类,最终都是委托给顶层的启动类加载器进行加载。
这样就保证了使用不同的类加载器最终得到的都是同一个object对象。


  1. OSGI:动态模型系统:面向java的动态模型系统,是java动态化模块化系统的一系列规范
上一篇下一篇

猜你喜欢

热点阅读