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

2018-07-19 00:53:37 +08:00
 kerb15

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

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

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

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

2655 次点击
所在节点    Java
5 条回复
picture2200
2018-07-19 06:56:14 +08:00
我是做 c#的,不过机制类似。如果平台没有,也会有第三方包做这个。

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

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

个人理解,如果有的不对的地方请指正。
kerb15
2018-07-19 09:40:42 +08:00
@shalk 感谢。不过我还有一个问题,如果加载器把类 A 以及它依赖的类 B 加载了,而类 C 中同样依赖了类 B,加载器是如何在加载类 C 的时候得知类 B 已经加载了的呢
shalk
2018-07-19 12:53:09 +08:00
@kerb15 同一个类加载器有缓存,见 findLoadedClass
mmdsun
2018-07-19 23:34:23 +08:00
补充一点。安全性。你自己写可以个 String 类就可以替换 jdk 的 String 类。双亲委派就可以防止这样情况发生!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/472186

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX