前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >死锁模拟

死锁模拟

作者头像
名字是乱打的
发布2021-12-24 09:12:37
4090
发布2021-12-24 09:12:37
举报
文章被收录于专栏:软件工程

死锁解释

  • 死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,
  • 若无外力干涉那它们都将无法推进下去,如果系统资源充足,进程的资源请求都能够得到满足,
  • 死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。

造成死锁的原因

  • 系统资源不足
  • 进程运行推进的顺序不合适
  • 资源分配不当

破解死锁,防止死锁

https://www.runoob.com/java/thread-deadlock.html

死锁模拟

代码语言:javascript
复制
package com.algorithm.future.lock;

import java.util.concurrent.TimeUnit;

/**
 * @description: 死锁模拟
 * @author: zyh
 **/
class DeathLock implements Runnable{
    private  String ziyuanA;
    private  String ziyuanB;

    public DeathLock(String lockA, String lockB) {
        this.ziyuanA = lockA;
        this.ziyuanB = lockB;
    }


    @Override
    public void run() {
        synchronized (ziyuanA){
            System.out.println(Thread.currentThread().getName()+"持有"+ ziyuanA +"尝试获得"+ziyuanB);
            //暂停线程//给另外一个线程时间去锁定另一个资源//若不锁定可能
            try{
                TimeUnit.SECONDS.sleep(5);
            }catch(InterruptedException e){
                e.printStackTrace();
            }

            //若这里获得不到ziyuanB将会进入等待
            synchronized (ziyuanB){
                System.out.println(Thread.currentThread().getName()+"持有"+ziyuanB+"尝试获得"+ ziyuanA);
            }

        }
    }
}

class DeathThread {
    public static void main(String[] args){
        String lockA="zylockAA";
        String lockB="zylockBB";
        new Thread(new DeathLock(lockA, lockB),"线程a").start();
        new Thread(new DeathLock(lockB, lockA),"线程b").start();
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/11/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 死锁解释
  • 造成死锁的原因
  • 破解死锁,防止死锁
  • 死锁模拟
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档