JVM 类加载机制

JVM 类加载机制分为五个部分:加载,验证,准备,解析,初始化,下面我们就分别来看一下这五个过程。

加载

加载是类加载过程中的一个阶段,这个阶段会在内存中生成一个代表这个类的

java.lang.class 对象,作为方区这个类的各种数据的入口,注意这里不一定非得要

从一个class文件获取,这里既可以从zip 包中读出(比如从 jar 包),也可以由其它文件

生成(比如将JSP文件 转换成对应的Class类)

验证

这一阶段的主要目的是为保证Class文件的字节流包含的信息是否符合当前虚拟机的要求

,并且不会危害虚拟自身的安全

准备

准备阶段是正式为类变量分配内存并设置类变量的初始值阶段,既在方法区中分配这些变量

所使用的内存空间,注意这里所说的初始值概念,比如一个类变量定义为:

public static int v=80;

准备阶段后初始值 为0 而不是80

解析

解析阶段将类中的符号引用转换为直接引用,即将类、方法和字段的引用解析为内存地址

初始化

初始化阶段是类加载最后一个阶段,前面的类加载阶段之后,除了在加载阶段可以自定义类加载器以外,其它操作都由 JVM 主导。到了初始阶段,才开始真正执行类中定义的 Java 程序代码。

初始化阶段是执行类构造器方法的过程。方法是由编译器自动收集类中的类变量的赋值操作和静态语句块中的语句合并而成的。虚拟机会保证子方法执行之前,父类的方法已经执行完毕,如果一个类中没有对静态变量赋值也没有静态语句块,那么编译器可以不为这个类生成()方法。

注意以下几种情况不会执行类初始化:

  1. 通过子类引用父类的静态字段,只会触发父类的初始化,而不会触发子类的初始化。

  2. 定义对象数组,不会触发该类的初始化。

  3. 常量在编译期间会存入调用类的常量池中,本质上并没有直接引用定义常量的类,不会触发定义常量所在的类。

  4. 通过类名获取 Class 对象,不会触发类的初始化。

  5. 通过 Class.forName 加载指定类时,如果指定参数 initialize 为 false 时,也不会触发类初始化,其实这个参数是告诉虚拟机,是否要对类进行初始化。

  6. 通过 ClassLoader 默认的 loadClass 方法,也不会触发初始化动作。

相关推荐
2301_809204703 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277774 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
冷小鱼5 小时前
JVM 异常崩溃排查全指南:从 Core Dump 到根因定位
jvm
2301_782040458 小时前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between
jvm·数据库·python
沐浴露z11 小时前
面试官:静态变量与非静态成员变量的区别?别再死记硬背了!
java·jvm
Chase_______15 小时前
Java 基础语言 ① —— Java 运行机制与开发环境:从 javac 到 JVM 全流程解析
java·jvm·python
xqqxqxxq15 小时前
多线程、进程与JVM 技术笔记
jvm·笔记
cui_ruicheng15 小时前
Linux线程(二):pthread 线程库与线程控制
java·开发语言·jvm
不知名的老吴16 小时前
C++20的jthread使用基础及实例分析
jvm
Devin~Y16 小时前
大厂Java面试实战:Spring Boot/Cloud、Redis/Kafka、JVM调优与Spring AI RAG(内容社区UGC+AIGC客服场景)
java·jvm·spring boot·redis·spring cloud·kafka·mybatis