深入了解JVM之类加载器

1 篇文章 0 订阅
1 篇文章 0 订阅

将这一段时间对JVM类加载器的了解简单描述一下,如有错误,欢迎提出。

类加载器概念

Java中的类加载器大致可以分为两类,一类是系统提供的,另一类是开发人员编写。系统提供的类加载主要有三个:

引导类加载器(bootstrap class loader):

        这是JVM的根ClassLoader,它是用C++实现的,并不继承自 java.lang.ClassLoader,JVM启动时初始化此ClassLoader,并由此ClassLoader完成$JAVA_HOME中jre/lib/rt.jar(Sun JDK的实现)中所有class文件的加载,这个jar中包含了java规范定义的所有接口以及实现

扩展类加载器(extensions class loader):

        Java 虚拟机的实现会提供一个扩展库目录。该类加载器在此目录里面查找并加载 Java 类

系统类加载器(system class loader):

        JVM用此classloader来加载启动参数中指定的Classpath中的jar包以及目录,在Sun JDK中ClassLoader对应的类名为AppClassLoader,可以通过 ClassLoader.getSystemClassLoader()来获取它

除了系统提供的类加载器以外,开发人员可以通过继承 java.lang.ClassLoader类的方式实现自己的类加载器,以满足一些特殊的需求。

类加载器树状结构图如下所示,其中箭头指向的是父类加载器:

获取父类加载器代码

package example;

import org.apache.tools.ant.taskdefs.Classloader;

public class ParentClassLoader {

	public static void main(String[] args) {
		//获取当前类 ParentClassLoader 的类加载器,为系统类加载器
		ClassLoader load=ParentClassLoader.class.getClassLoader();
		System.out.println(show(load));
		//调用getParent()方法,获取其父类加载器-扩展类加载器
		load=load.getParent();
		System.out.println(show(load));
		//调用getParent()方法,获取其父类加载器 为空
		load=load.getParent();
		System.out.println(show(load));

	}
	
	static String show(ClassLoader classloader){
		return classloader==null?"null":classloader.toString();
	}

}

输出结果:

sun.misc.Launcher$AppClassLoader@456d3d51
sun.misc.Launcher$ExtClassLoader@6d4b473
null


加载类的过程

        调用loadClass(classname)方法加载指定名字的类,首先 调用findLoadedClass(classname)从已经加载的类缓存中查找,如果存在,直接返回;

否则调用loadClass(classname, false)继续从父加载器中查找,直至引导类加载器;如果仍不存在,再从当前类加载器(大多数是System ClassLoader)加载,

最后才从类路径中导入字节码源文件,调用defineClass(name, 字节码字节流, 0, 字节流长度)生成类实例并返回,这个加载过程采用类加载的委托机制,也称为

代理模式。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVM的类是由类及其子类实现的。类是Java运行时系统的重要组成部分,负责在运行时查找和类文件中的类。在JVM中,类按照一定的层次结构进行组织,每个类负责特定位置的类。其中,启动类(Bootstrap ClassLoader)是负责存放在<JAVA_HOME>/lib目录中的核心类库,如rt.jar、resources.jar等,同时也可以通过-Xbootclasspath参数指定的路径中的类库。启动类是用C语言编写的,随着JVM启动而。当JVM需要使用某个类时,它会通过类查找并这个类。过程会经历连接阶段,包括验证、准备和解析。在验证阶段,JVM会确保的类信息符合JVM规范。在准备阶段,JVM会为类变量分配内存并设置初始值,在方法区中分配这些内存。在解析阶段,JVM会根据符号引用替换为直接引用,以便后续的使用。通过类的协同工作,JVM能够在运行时动态类,从而实现Java的灵活性和跨平台性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [JVM 的类原理](https://blog.csdn.net/ChineseSoftware/article/details/119212339)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [JVM](https://blog.csdn.net/rockvine/article/details/124825354)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值