先附上死锁代码:package test;
public class lock {
public static Object lock1=new Object();
public static Object lock2=new Object();
public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
synchronized (lock1) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock2) {
System.out.println("enter thread:"+Thread.currentThread().getName()+"的锁2");
}
}
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
synchronized (lock2) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock1) {
System.out.println("enter thread:"+Thread.currentThread().getName()+"的锁2");
}
}
}
}).start();
}
public class lock {
public static Object lock1=new Object();
public static Object lock2=new Object();
public static void main(String[] args) {
new Thread(new Runnable() {
@Override
public void run() {
synchronized (lock1) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock2) {
System.out.println("enter thread:"+Thread.currentThread().getName()+"的锁2");
}
}
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
synchronized (lock2) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock1) {
System.out.println("enter thread:"+Thread.currentThread().getName()+"的锁2");
}
}
}
}).start();
}
}
2、jps 查看进程pid,此处获取pid为13752
14868
2660
13752 lock
3、jstack pid查看死锁状态: