首页 > 代码库 > Java线程死锁
Java线程死锁
Java多线程使用synchronized 锁时,可能会出现死锁;死锁会导致两个线程无限等待,致使程序异常。因此使用synchronized 关键字时注意死锁的问题。
笔者在第一次运行程序的时候属性 A=“a”、B=“a”,并没有引起死锁的问题;原因很简单,这时A 和 B的地址是一样的,synchronized 认为是同一个对象资源,不会对对象A 和 B同时加锁。
引起死锁的例子:
public class DeadLock {
private String A = "a";
private String B = "b";
@SuppressWarnings("static-access")
public void deadLock(){
Thread thread1 = new Thread(new Runnable(){
@Override
public void run() {
System.out.println("thread1-start");
synchronized (A) {
System.out.println("1" + A);
try {
Thread.currentThread().sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
synchronized (B){
System.out.println("2" + B);
}
}
System.out.println("thread1-end");
}
});
Thread thread2 = new Thread(new Runnable(){
@Override
public void run() {
System.out.println("thread2-start");
synchronized (B) {
System.out.println("3" + B);
synchronized (A){
System.out.println("4" + A);
}
}
System.out.println("thread2-end");
}
});
thread1.start();
thread2.start();
}
public static void main(String[] args){
new DeadLock().deadLock();
}
}
Java线程死锁
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。