死锁
不同的线程分别占用对方需要的同步资源不放弃,都在等待对方放弃自己的需要的同步资源,就形成了线程的死锁
解决方法
1.专门的算法、原则
2.尽量减少同步资源的定义
不同的线程分别占用对方需要的同步资源不放弃,都在等待对方放弃自己的需要的同步资源,就形成了线程的死锁
解决方法
1.专门的算法、原则
2.尽量减少同步资源的定义
此处插入TestDeadLock
//死锁问题,处理线程同步时容易出现
public class TestDeadLock {
static StringBuffer sb1=new StringBuffer();
static StringBuffer sb2=new StringBuffer();
public static void main(String[] args) {
new Thread(){
public void run(){
synchronized(sb1){
try {
Thread.currentThread().sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sb1.append("A");
synchronized(sb2){
sb2.append("B");
System.out.println(sb1);
System.out.println(sb2);
}
}
}
}.start();
new Thread(){
public void run(){
synchronized(sb2){
try {
Thread.currentThread().sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
sb2.append("C");
synchronized(sb1){
sb1.append("D");
System.out.println(sb1);
System.out.println(sb2);
}
}
}
}.start();
}
}