这一章节我们来展示一下死锁。
1.代码清单
package com.ray.deepintothread.ch02.topic_21;
/**
*
* @author RayLee
*
*/
public class DeadLock {
public static void main(String[] args) throws InterruptedException {
MyService myService = new MyService();
ThreadOne threadOne = new ThreadOne(myService);
Thread thread = new Thread(threadOne);
thread.start();
ThreadTwo threadTwo = new ThreadTwo(myService);
Thread thread2 = new Thread(threadTwo);
thread2.start();
}
}
class ThreadOne implements Runnable {
private MyService myService;
public ThreadOne(MyService myService) {
this.myService = myService;
}
@Override
public void run() {
try {
myService.updateA();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
class ThreadTwo implements Runnable {
private MyService myService;
public ThreadTwo(MyService myService) {
this.myService = myService;
}
@Override
public void run() {
try {
myService.updateB();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
class MyService {
private Object object1 = new Object();
private Object object2 = new Object();
public void updateA() throws InterruptedException {
System.out.println(Thread.currentThread().getName());
synchronized (object1) {
System.out.println("synch obj1");
Thread.sleep(1000);
synchronized (object2) {
System.out.println("synch obj2");
}
}
}
public void updateB() throws InterruptedException {
System.out.println(Thread.currentThread().getName());
synchronized (object2) {
System.out.println("synch obj2");
Thread.sleep(1000);
synchronized (object1) {
System.out.println("synch obj1");
}
}
}
}
输出:
Thread-0
synch obj1
Thread-1
synch obj2
(然后一直等。。。。。)
2.死锁形成的条件
两个线程都持有对方所需要的锁,同时也等待对方释放自己需要的锁,形成线程假死状态
总结:这一章节只是简单的展示一下死锁,后面会有一个单独的大章来阐述锁的问题。
这一章节就到这里,谢谢
------------------------------------------------------------------------------------
我的github:https://github.com/raylee2015/DeepIntoThread
目录:http://blog.csdn.net/raylee2007/article/details/51204573