jvm类加载器

ClassLoader

classLoader主要使用java编写,部分使用c++编写
classLoader主要获取类的字节码
jdk8及之前
底层实现bootstrap加载java核心类比如String等(无法获取,只能通过参数配置(推荐),或放入jre/lib拓展(不推荐))
java实现extension拓展加载器(通过参数配置但会覆盖原目录,两个都要指定,分号分隔(推荐),或放入文件夹拓展(不推荐)),Application应用程序类加载器(maven配置和其余类加载)

双亲委派机制
类加载要求:1.安全
       2.避免重复加载
bootstrap->extension->Application
1.类加载过程会从右向左委派查找(检查有无加载),再从左向右的尝试加载
2.三者存在父子关系
3.确保核心库安全,完整

打破双亲委派机制三种方式


1.自定义类加载器


    当两个类的全限定名相同时,就不可以同时加载,入tomcat运行两个web服务时就会出现冲突(相同类名),不够tomcat通过为每一个应用分配一个应用类加载器,打破双亲委派机制。
自定义实现
(1)类继承ClassLoader类,重写loadClass方法
(2)loadClass中获取被加载类数据(loadClassData)
(3)调用defineClass完成类加载
注:加载类的时候会要求所有类都继承父类(默认object类),不然会报错,可以将待加载类同目录放入父类,也可直接将父类交由ClassLoader中的类加载器加载,在一个Java虚拟机中,只有同一个类加载器外加相同的类限定名才会认为冲突


2.线程上下文类加载器(spi机制)


(1)在classPath路径下的META-INF/services文件夹中,以接口全限定名来约定文件名(同时写入文件),对应文件里面写该接口实现(比如mysql驱动)
(2)serviceLoader加载实现类
注:实际使用的类加载器是线程上下文中的类加载器(application类加载器),可通过Thread.currentThread().getContextClassLoader()获取,也可以手动设置自定义类加载器,这种方式在驱动的加载中任然依赖于双亲委派机制
完整流程:bootstrap加载DriverManager,再通过DriverManger通过spi机制加载其他类


3.osgi框架类加载器(以不在使用)

:自己实现了一套加载机制,实现了类的热部署,现在可用arthas实线
终:打破双亲委派机制的唯一方式就是重写ClassLoader

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值