线程问题-死锁问题

死锁问题,在设计程序时就应该避免双方相互持有对方的锁的情况
package com.tt.thread;
public class DeadLock implements Runnable {
private String tag;
private static Object lock1 = new Object();
private static Object lock2 = new Object();
public void setTag(String tag) {
this.tag = tag;
}
@Override
public void run() {
if (tag.equals(“a”)) {
synchronized (lock1) {
try {
System.out.println(“当前线程 : ” + Thread.currentThread().getName() + ” 进入lock1执行”);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock2) { //持有lock2的线程没有被执行
System.out.println(“当前线程 : ” + Thread.currentThread().getName() + ” 没有进入lock2执行”);
}
}
}
if (tag.equals(“b”)) {
synchronized (lock2) {
try {
System.out.println(“当前线程 : ” + Thread.currentThread().getName() + ” 进入lock2执行”);
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock1) { //持有lock1的线程没有被执行
System.out.println(“当前线程 : ” + Thread.currentThread().getName() + ” 没有进入lock1执行”);
}
}
}
}
public static void main(String[] args) {

    DeadLock d1 = new DeadLock();
    d1.setTag("a");
    DeadLock d2 = new DeadLock();
    d2.setTag("b");

    Thread t1 = new Thread(d1, "t1");
    Thread t2 = new Thread(d2, "t2");

    t1.start();
    try {
        Thread.sleep(500);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    t2.start();
}

}

当前线程 : t1 进入lock1执行
当前线程 : t2 进入lock2执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值