博客
关于我
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/

    你可能感兴趣的文章
    OpenCV与AI深度学习 | CIB-SE-YOLOv8: 优化的YOLOv8, 用于施工现场的安全设备实时检测 !
    查看>>
    OpenCV与AI深度学习 | CoTracker3:用于卓越点跟踪的最新 AI 模型
    查看>>
    OpenCV与AI深度学习 | OpenCV中八种不同的目标追踪算法
    查看>>
    OpenCV与AI深度学习 | OpenCV图像拼接--Stitching detailed使用与参数介绍
    查看>>
    OpenCV与AI深度学习 | OpenCV如何读取仪表中的指针刻度
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(一) :直接拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(三):基于特征匹配拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(二) :基于模板匹配拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV常用图像拼接方法(四):基于Stitcher类拼接
    查看>>
    OpenCV与AI深度学习 | OpenCV快速傅里叶变换(FFT)用于图像和视频流的模糊检测(建议收藏!)
    查看>>
    OpenCV与AI深度学习 | PaddleOCR 2.9 发布, 正式开源文本图像智能分析利器
    查看>>
    OpenCV与AI深度学习 | SAM2(Segment Anything Model 2)新一代分割一切大模型介绍与使用(步骤 + 代码)
    查看>>
    OpenCV与AI深度学习 | T-Rex Label !超震撼 AI 自动标注工具,开箱即用、检测一切
    查看>>
    OpenCV与AI深度学习 | YOLO11介绍及五大任务推理演示(目标检测,图像分割,图像分类,姿态检测,带方向目标检测)
    查看>>
    OpenCV与AI深度学习 | YOLOv10在PyTorch和OpenVINO中推理对比
    查看>>
    OpenCV与AI深度学习 | YOLOv11来了:将重新定义AI的可能性
    查看>>
    OpenCV与AI深度学习 | YOLOv8自定义数据集训练实现火焰和烟雾检测(代码+数据集!)
    查看>>
    OpenCV与AI深度学习 | YOLOv8重磅升级,新增旋转目标检测,又该学习了!
    查看>>
    OpenCV与AI深度学习 | 一文带你读懂YOLOv1~YOLOv11(建议收藏!)
    查看>>
    OpenCV与AI深度学习 | 五分钟快速搭建一个实时人脸口罩检测系统(OpenCV+PaddleHub 含源码)
    查看>>