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

    你可能感兴趣的文章
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>
    npm报错Failed at the node-sass@4.14.1 postinstall script
    查看>>
    npm报错fatal: Could not read from remote repository
    查看>>
    npm报错File to import not found or unreadable: @/assets/styles/global.scss.
    查看>>
    npm报错TypeError: this.getOptions is not a function
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
    查看>>
    npm版本过高问题
    查看>>
    npm的“--force“和“--legacy-peer-deps“参数
    查看>>
    npm的安装和更新---npm工作笔记002
    查看>>
    npm的常用操作---npm工作笔记003
    查看>>
    npm的常用配置项---npm工作笔记004
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>
    npm编译报错You may need an additional loader to handle the result of these loaders
    查看>>
    npm设置淘宝镜像、升级等
    查看>>
    npm设置源地址,npm官方地址
    查看>>
    npm设置镜像如淘宝:http://npm.taobao.org/
    查看>>
    npm配置安装最新淘宝镜像,旧镜像会errror
    查看>>
    NPM酷库052:sax,按流解析XML
    查看>>
    npm错误 gyp错误 vs版本不对 msvs_version不兼容
    查看>>