java 模拟线程死锁_Java 代码模拟死锁

题目描述

Java代码模拟死锁

死锁条件

互斥使用:一个资源只能分配给一个线程

不可剥夺:资源只能由占有者释放,申请者不能强制剥夺

请求保持:线程申请资源时,保持对原有资源的占有

循环等待:存在一个进程等待队列:{P1 , P2 , … , Pn}, 其中P1等待P2占有的资源,P2等待P3占有的资源,…,Pn等待P1占有的资源,形成一个进程等待环路

代码

思路

定义两个资源o1,o2

对象deadLock1占有资源o1,需要资源o2

对象deadLock2占有资源o2,需要资源o1

死锁产生

代码

public class DeadLock implements Runnable {

// flag=1,占有对象o1,等待对象o2

// flag=0,占有对象o2,等待对象o1

public int flag = 1;

// 定义两个Object对象,模拟两个线程占有的资源

public static Object o1 = new Object();

public static Object o2 = new Object();

public static void main(String[] args) {

DeadLock deadLock1 = new DeadLock();

DeadLock deadLock2 = new DeadLock();

deadLock1.flag = 0;

deadLock2.flag = 1;

Thread thread1 = new Thread(deadLock1);

Thread thread2 = new Thread(deadLock2);

thread1.start();

thread2.start();

}

public void run() {

System.out.println("flag: " + flag);

// deadLock2占用资源o1,准备获取资源o2

if (flag == 1) {

synchronized (o1) {

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

synchronized (o2) {

System.out.println("1");

}

}

}

// deadLock1占用资源o2,准备获取资源o1

else if (flag == 0) {

synchronized (o2) {

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

e.printStackTrace();

}

synchronized (o1) {

System.out.println("0");

}

}

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值