博客
关于我
ClassLoader、双亲委派机制、自定义类加载器实践
阅读量:397 次
发布时间:2019-03-05

本文共 1207 字,大约阅读时间需要 4 分钟。

ClassLoader、双亲委派机制、自定义类加载器

双亲委派模型是Java类加载机制中的一个核心原理,它确保了类的加载安全性和唯一性。以下是对这一机制的详细分析:

  • 双亲委派机制的工作原理

    • 当一个类加载器要加载某个类时,它会首先询问其上级类加载器(父类加载器)是否已经加载了该类。
    • 如果上级已经加载了该类,当前类加载器就不需要再去处理这个类,直接返回已加载的类。
    • 如果上级没有加载过,该类加载器会继续向上级的父类加载器请求,直到顶层的Bootstrap ClassLoader。
    • 如果在整个过程中找到了该类的定义,加载过程就停止,否则会抛出ClassNotFoundException。
    • 重要的是,如果一个类已经被加载过,就不会再次尝试加载,从而避免了重复加载带来的问题。
  • 类加载器的层级结构

    • Bootstrap ClassLoader(启动类加载器):负责加载Java核心类和rt.jar中的类,通常位于$JAVA_HOME/jre/lib/rt.jar。
    • Extension ClassLoader(扩展类加载器):负责加载扩展目录$JAVA_HOME/jre/lib/ext/下的jar文件。
    • Application ClassLoader(应用类加载器):负责加载应用程序的类路径(-jarpath或-classpath)。
    • User ClassLoader(用户类加载器):由开发者自定义,通常用于定制加载逻辑,例如加密类文件或读取特定目录中的类。
  • 双亲委派的优势

    • 安全性:确保核心类库无法被自定义类加载器覆盖,防止潜在的安全风险。例如,自定义类加载器尝试加载java.lang开头的类时,会抛出SecurityException。
    • 避免重复加载:已加载的类不会重复加载,减少内存占用和逻辑混乱。
  • 自定义类加载器的实现

    • 要自定义类加载器,必须继承ClassLoader类,并覆盖findClass方法。
    • 例如,MyClassLoader2类读取指定路径下的class文件,并使用defineClass方法定义类。
    • 注意:传统的defineClass方法已过时,建议使用带有name参数的方法,以便通过类路径加载类。
  • 实践中的挑战与思考

    • 定义java.lang类:尝试定义自己的java.lang.String或Object类时,会发现这些类会被Bootstrap ClassLoader优先加载,确保了系统的稳定性。
    • 自定义类在扩展目录中的加载:如果将自定义类打包到jre/lib/ext目录中,Extension ClassLoader会优先加载这些类,确保不会使用应用类加载器中的类。
    • 测试与验证:通过编写测试类,验证自定义类加载器是否能够正确加载自定义类,并确保双亲委派机制的正确性。
  • 通过理解双亲委派机制和自定义类加载器的实现,可以更好地掌握Java的类加载机制,灵活地进行类加载管理。

    转载地址:http://lkdzz.baihongyu.com/

    你可能感兴趣的文章
    nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>