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锁
    原文地址: http://www.cnblogs.com/lyxb/p/7325165.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞