V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kerb15
V2EX  ›  Java

为什么 Java 类加载器要“全盘负责”?

  •  
  •   kerb15 · 2018-07-19 00:53:37 +08:00 · 2623 次点击
    这是一个创建于 2079 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我们都知道类加载器有“全盘负责”的机制,就是当一个类加载器负责加载某个 Class 时,该 Class 所依赖的和引用的其他 Class 也将由该类加载器负责载入,除非显式指定另外一个类加载器来载入。

    而“双亲委派”机制则会将类的加载请求委托给父类。

    这样的话,如果一个类加载器加载某一个类 A 的时候,那么该类所依赖的其他类 B 也就由当前这个类加载器加载了,这跟“双亲委派”机制矛盾吗?

    我想知道“全盘负责”的作用是什么?搜了下发现网上都只说了概念,没说为什么。

    5 条回复    2018-07-19 23:34:23 +08:00
    picture2200
        1
    picture2200  
       2018-07-19 06:56:14 +08:00 via Android
    我是做 c#的,不过机制类似。如果平台没有,也会有第三方包做这个。

    总之到我这里没有这种机制没办法搞 DI。难道要花时间自己整?在平台内部做应该是最容易的。
    shalk
        2
    shalk  
       2018-07-19 08:57:43 +08:00 via iPhone   ❤️ 1
    我觉得这件事情自然而然,也不是什么机制,主要是保证双亲委派,举个例子,如果不全负责,例如加载器 1 在加载 class A,A 中出现了 B,假定不用双亲或者自身去加载,用加载器 2 去加载,如果 B 中又出现 A,又必须知道用哪个加载器去加载,是否加载过,加载器之间如何知道彼此。这样会把问题弄复杂。

    所以只要清楚双亲委派的目的保证类的唯一性,即用简单的方式解决问题。

    个人理解,如果有的不对的地方请指正。
    kerb15
        3
    kerb15  
    OP
       2018-07-19 09:40:42 +08:00 via Android
    @shalk 感谢。不过我还有一个问题,如果加载器把类 A 以及它依赖的类 B 加载了,而类 C 中同样依赖了类 B,加载器是如何在加载类 C 的时候得知类 B 已经加载了的呢
    shalk
        4
    shalk  
       2018-07-19 12:53:09 +08:00 via iPhone
    @kerb15 同一个类加载器有缓存,见 findLoadedClass
    mmdsun
        5
    mmdsun  
       2018-07-19 23:34:23 +08:00 via Android   ❤️ 1
    补充一点。安全性。你自己写可以个 String 类就可以替换 jdk 的 String 类。双亲委派就可以防止这样情况发生!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3205 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 11:58 · PVG 19:58 · LAX 04:58 · JFK 07:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.