JVM学习笔记(二):类加载器

2. 类加载子系统

2.1 内存概述

  • 类装载器:将字节码文件加载到内存中;

在这里插入图片描述

2.2 类加载器

自定义类加载器->AppClassLoader(系统类加载器) -> ExtClassLoader(扩展类加载器) -> BootstrapClassLoader(引导类加载器)

  • 引导类加载器BootstrapClassLoader
  1. 使用C/C++语言实现的,嵌套在JVM内部,无法通过Java代码获取
  2. 用来加载核心类库($JAVA_HOME/jre/lib/rt.jar,resource.jar,或者sun.boot.class.path路径下的内容),用于提供JVM自身需要的类
  3. 处于安全考虑,Bootstrap启动类加载器只加载包名为java,javax,sun等开头的类
//获取Bootstrap加载器加载的路径
URL[] urLs = Launcher.getBootstrapClassPath().getURLs();
for (URL urL : urLs) {
System.out.println("引导类加载器路径>>>" + urL.toExternalForm());
}
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/rt.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/sunrsasign.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/jsse.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/jce.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/charsets.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/jfr.jar
引导类加载器路径>>>file:/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/classes
  • 扩展类加载器ExtClassLoader
  1. Java语言编写,派生于ClassLoader类
  2. 负责加载jre/lib/ext扩展目录下的类库,如果用户自建的JAR放在此目录下,也会自动由扩展加载器加载
  3. 也可用java.ext.dirs配置用ext加载器加载的目录,该配置目录下也由扩展类加载器加载
  4. 虚拟机自带的加载器
String property = System.getProperty("java.ext.dirs");
for (String s : property.split(";")) {
		System.out.println("扩展类加载器>>>"+s);
}
扩展类加载器>>>/Users/dinl/Library/Java/Extensions
扩展类加载器>>>/Library/Java/JavaVirtualMachines/jdk1.8.0_172.jdk/Contents/Home/jre/lib/ext
扩展类加载器>>>/Library/Java/Extensions
扩展类加载器>>>/Network/Library/Java/Extensions
扩展类加载器>>>/System/Library/Java/Extensions
扩展类加载器>>>/usr/lib/java
  • 系统类加载器AppClassLoader
  1. Java语言编写,派生于ClassLoader,继承自ExtClassLoader
  2. 用java.class.path配置AppClassLoader的加载目录
  3. 该类加载器是程序中的默认类加载器
  4. 除了前面两个类加载器之外的类都是由自定义类加载器加载的

2.3 双亲委派机制

Java虚拟机对class文件采用的是按需加载的方式,也就是说当需要用到该类时才将它的class文件加载到内存中生成class对象,加载机制为双亲委派机制,就是把请求交给父类处理,它是一种任务委派机制.

双亲委派机制模型的工作过程: 如果一个类加载器收到了类加载的请求,它首先不会自己尝试去加载这个类.而是把请求委派给父类加载器去完成,每一个层次的类加载器都是如此,因此所有的加载请求最终都应该传送到顶层的启动类加载器中.只有当父类反馈无法加载时,子加载器才尝试自己去加载.
使用双亲委派机制来组织类加载器之间的关系,有一个显而易见的好处就是Java的类随着它的加载器一起具备了一种带有优先级的层次关系.如果没有使用双亲委派加载模型,各个类都自己去加载的话,如果用户自己编写了一个java.lang.Object类,并放在程序的classPath中,那么系统中就会出现多个不同的Object类,java体系的最基本功能就无法得到保证了.

优势
  • 避免类的重复加载
  • 保护程序安全,防止核心API被随意篡改
  • 1
    点赞
  • 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、付费专栏及课程。

余额充值