峨眉山月半轮秋,影入平羌江水流
Java线程的死锁一直都是经典的多线程问题;因为不同的线程都在等待根本不可能被释放的锁,从而导致所有的任务都不能继续执行;
示例代码:
public class ThreadTest {
public static void main(String[] args) {
try{
MyThread thread = new MyThread();
thread.setName("a");
Thread thread1 = new Thread(thread);
thread1.start();
Thread.sleep(100);
thread.setName("b");
Thread thread2 = new Thread(thread);
thread2.start();
}catch (Exception e) {
e.printStackTrace();
}
}
}
class MyThread implements Runnable{
private String name;
public Object obj1 = new Object();
public Object obj2 = new Object();
public void setName(String name) {
this.name = name;
}
@Override
public void run() {
if (name.equals("a")) {
synchronized (obj1) {
try {
System.out.println("name = " + name);
Thread.sleep(3000);
}catch (Exception e) {
e.printStackTrace();
}
synchronized (obj2) {
System.out.println("执行到obj2了");
}
}
}
if (name.equals("b")) {
synchronized (obj2) {
try {
System.out.println("name = " + name);
Thread.sleep(3000);
}catch (Exception e) {
e.printStackTrace();
}
synchronized (obj1) {
System.out.println("执行到obj1了");
}
}
}
}
}
运行结果:
这里是因为当name为a的时候,obj2一直被变量name等于的b那个线程占用,没有释放,同理,变量为b的obj1一直在等待上面的那个线程释放锁…从而形成死锁.
其实,通过JDK自带的工具也可以看到死锁的现象:
使用管理员的身份打开CMD窗口,进入到jdk安装目录的bin文件夹下.执行jps命令:
从而得知线程的ID为4856;然后执行jstack -l 4856:
由此可以看出,程序设计得出现了死锁;
所以,在设计程序时,要尽量避开死锁的陷阱;