原文官方地址
http://docs.oracle.com/javase/7/docs/technotes/guides/lang/cl-mt.html
但是看得不太懂,忘懂的人赐教一下,并且举例一般什么情况下会出现这种情况,jdk7是如何解决的
[quote]并且举例一般什么情况下会出现这种情况[/quote]
他里面那段就是举例。
注意是以前的版本。
Class Hierarchy:类继承关系
class A extends B
class C extends D
ClassLoader Delegation Hierarchy:类加载继承关系
Custom Classloader CL1:
directly loads class A
delegates to custom ClassLoader CL2 for class B
类加载器1 CL1,企图直接加载类A,导致其中代理的类加载器CL2,企图加载类B。
Custom Classloader CL2:
directly loads class C
delegates to custom ClassLoader CL1 for class D
类加载器2 CL2,企图直接加载类C,导致其中代理的类加载器CL1,企图加载类B。
Thread 1:
Use CL1 to load class A (locks CL1)
defineClass A triggers
loadClass B (try to lock CL2)
Thread 2:
Use CL2 to load class C (locks CL2)
defineClass C triggers
loadClass D (try to lock CL1)
简单说,就是两个类加载器在两个线程中,按不同顺序一先一后的企图开始加载类。
由于以前版本的JDK是整个类加载器的上锁,
即一个线程拿着CL1的锁请求CL2的锁,另个却拿着CL2的锁请求CL1的锁,
导致死锁。
[quote]jdk7是如何解决的[/quote]
JDK7在个类加载器上锁时,可以做更小的粒度。
在上面的例子里,新版本不再是整个类加载器上锁,而是类加载器 + 待加载的类(类名)。解决了上面的问题。
后面的详细步骤就不翻译了。
基本上,如果你的类加载器以前没有出现过死锁,就不用折腾。或者你没有像上面的例子那样循环套循环,也不用太注意这个问题。