死锁

同步锁使用的弊端:当线程任务中出现了多个同步(多个锁),如果同步中嵌套了其他的同步。这时容易引发一种现象:程序出现无限等待,这种现象就是我们所谓的死锁,这种情况能避免就避免。


/**
*
*创建锁对象
*
*/
public class Lock {
//这里用private封装,为了不让外面随便造锁,限制只能有A,B锁个一把,这样容易出现死锁
//即A同学和B同学想相互串门,可是没人只有一把自己房间的钥匙,而且各自都不愿意先给,于是死锁
private Lock() {};
public static final Object lockA =new Object();
public static final Object lockB = new Object();
//这里使用static 为了让外界可以通过类名调用成员变量lockA和lockB
//因为外面无法创建Lock对象,为了让外面在不创对象的情况下调用,加了static,通过类名加变量名访问
}

/**
* 线程任务类
*
*/
import java.util.Random;

public class ThreadTask implements Runnable {
int x = new Random().nextInt(1);//用随机数随机获取0、1,来模拟CPU随机分配执行权的行为
@Override
public void run() {
while(true) {
if(x%2==0) {
//情况一
// 先执行A再执行B:即A同学先拿了A门的钥匙去开A门,然后打算开B门
synchronized(Lock.lockA) {
System.out.println("A同学...开A门");
synchronized(Lock.lockB) {
System.out.println("A同学...开B门");
}
}
}else {
//情况二
// 先执行B执行A:B同学先拿了B门的钥匙,去开B门,然后打算开A门
synchronized(Lock.lockB) {
System.out.println("B同学...开B门");
synchronized(Lock.lockA) {
System.out.println("B同学...开A门");
}
}
}
x++;
}

}

/**
*
* 线程测试类
*
*/
public class ThreadDemo {
public static void main(String[] args) {
//创建Runnable的实现类对象
ThreadTask tt = new ThreadTask();
//把Runnable实现类对象加入线程中,创建2个线程
Thread t1 = new Thread(tt);
Thread t2 = new Thread(tt);
t1.start();
t2.start();

}
*********************************************************
输出结果:A同学...开A门
     A同学...开B门
     B同学...开B门
     B同学...开A门
     A同学...开A门
     B同学...开B门
结论:A同学或者B同学,一个人先后拿走两把钥匙时,线程是正常运行的,一旦A拿了A锁进去A门的时候,CPU突然让B开始执行,让B拿了B锁进入B门,结果A需要B锁,B也需要A锁,两者又不能后退
于是死锁现象发生了。

转载于:https://www.cnblogs.com/q1051137184/p/9748572.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值