JVM类加载过程

Java类加载机制与双亲委派模型详解
本文详细介绍了Java的类加载过程,包括加载、链接(验证、准备、解析)、初始化阶段。强调了双亲委派模型的作用,如避免类的重复加载和保证核心类的安全。同时,解释了如何自定义类加载器以及如何打破双亲委派模型,如在特定场景下如热部署中。此外,还涉及类加载器的工作原理和静态变量与this的使用区别。

类加载

咱们都知道,类加载器分为四种,自定义类加载器、APP类加载器、Ext类加载器,BS类加载器

代码执行分为:混合执行、编译执行、解释执行。

加载过程:
1、loading:把class文件加载到内存
2、linking:动态连接
3、initializing:静态变量赋初始值(静态代码块)

loading:把class文件加载到内存

1、双亲委派

双亲委派解决了什么问题

1、解决重复加载,浪费资源
2、为了安全,防止核心数据被盗取;(比如重写String类,输入密码后记录发送邮件获取密码)

双亲委派是怎么工作的呢?

在这里插入图片描述

当类加载器接收到需要加载一个类请求的时候,首先去内存中查找这个类有没有被加载过,如果找到了直接返回,如果没有找,就会触发class的加载方法,parent.loadClass(name, false),(咱们都知道,自己的写的代码要么是自定义类开始加载器加载,要么是App类加载器开始加载),假如自定义类加载器开始加载,按照代码逻辑判断父类加载器是否存在,如果存在继续递归类加载器的父类进行加载,直到找到BS类加载器。这时就会从上向下递归加载,只要加载到了,就直接返回了。

如何自定义类加载器?

1、extends ClassLoader
2、overwrite findClass()->defineClass(byte[]->Class class)

双亲委派如何打破
1、parent是如何指定:在构造中super(parent)指定
2、双亲委派如何打破
	1、重写loadClass()
	2、何时被打破过
		1、JDK1.2指定,自定义ClassLoad都必须重写loadClass
		2、多线程情况设置thread.setContextClassLoader指定
		3、热启动,热部署
			1、osgi tomcat都有自己的模块指定classloader(可以加载统一类库的不同版本)

linking

1、verification:对class文件校验
2、preparation:class–>静态变量赋默认值
3、resolution:把class中的符号引用转换成直接引用
将类、方法、属性等符号引用解析为直接引用
常量池中的各种符号引用解析为指针、偏移量等内存的直接引用

initializing

当类加载器把一个class文件加载到内存后会生成两份,一份是class文件信息,一份是class类(帮助解析内存中类的二进制信息),class类的引用指向内存中class信息。

看到这里是不是心理有个疑问,为什么静态类不能使用this,而非静态对象可以使用this ???

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值