【线程死锁】
原因:两个线程相互等待被对方锁定的资源
代码模拟:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
public class deadlock {
public static void main(string[] args) {
object obj = new object();
object obj1 = new object();
deadlockthread1 d1 = new deadlockthread1(obj, obj1);
deadlockthread2 d2 = new deadlockthread2(obj, obj1);
new thread(d1, "线程1" ).start();
new thread(d2, "线程2" ).start();
}
}
class deadlockthread1 implements runnable {
private object obj;
private object obj1;
public deadlockthread1(object obj, object obj1) {
this .obj = obj;
this .obj1 = obj1;
}
@override
public void run() {
synchronized (obj) { //deadlockthread1锁定obj对象
try {
thread.sleep( 1000 );
synchronized (obj1) { //等待锁定obj1对象,obj对象已被deadlockthread2锁定
obj1.getclass();
}
} catch (interruptedexception e) {
e.printstacktrace();
}
}
}
}
class deadlockthread2 implements runnable {
private object obj;
private object obj1;
public deadlockthread2(object obj, object obj1) {
this .obj = obj;
this .obj1 = obj1;
}
@override
public void run() {
synchronized (obj1) { //deadlockthread2锁定obj2对象
try {
thread.sleep( 1000 );
synchronized (obj) { //等待锁定obj对象,obj对象已被deadlockthread1锁定
obj.getclass();
}
} catch (interruptedexception e) {
e.printstacktrace();
}
}
}
}
|
查看方式:
1、【cmd】下输入【jconsole】
2、选择测试线程并点击右下角【连接】,左上角选择【线程】,左下角选择【检测死锁】
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望通过本文能帮助到大家,谢谢大家对本站的支持!
原文链接:http://blog.csdn.net/rickiyeat/article/details/52558047