什么是死锁
不同的资源分别占用对方所需要的同步资源不放弃,都在等对方放弃自己所需要的同步资源,
就形成了死锁,出现死锁后不出现异常,不出现提示,所有线程处于阻塞状态,无法继续
举个例子
以下程序两个线程我们称为a和b,两个锁称为s1和s2
程序开始a线程执行,拿到s1锁后0.1秒阻塞,而后大概率执行线程b,线程b拿到s2锁后想执行下去发现s1锁已经被拿了,转到线程a,线程a发现s2锁也被占用,两个线程就僵持下去,不继续运行也不提示错误
public static void main(String[] args) {
StringBuffer s1 = new StringBuffer();
StringBuffer s2 = new StringBuffer();
new Thread(){
@Override
public void run(){
synchronized (s1){
s1.append("a");
s2.append("1");
try {
Thread.sleep(100);//线程阻塞
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (s2){
s1.append("b");
s2.append("2");
System.out.println(s1);
System.out.println(s2);
}
}
}
}.start();
new Thread(new Runnable() {
@Override
public void run() {
synchronized (s2){
s1.append("c");
s2.append("3");
synchronized (s1){
s1.append("d");
s2.append("4");
System.out.println(s1);
System.out.println(s2);
}
}
}
}){}.start();
}
其实在实际开发中,死锁问题比这个更加复杂,不容易发现
解决方法就是使用特定算法和不使用同步资源