当前位置:首页 > 科技  > 软件

Java并发:如何避免死锁

来源: 责编: 时间:2024-04-02 17:12:06 239观看
导读一般在Java项目里用到锁的场景不多,有朋友调侃说用到锁的次数还没有面试被问到的次数多,哈哈!1.死锁如何产生说句难听话,锁一般都很少用到,何况死锁呢?想产生死锁还是有点难的,需要满足2个条件:共享资源同时只能被一个线程使

一般在Java项目里用到锁的场景不多,有朋友调侃说用到锁的次数还没有面试被问到的次数多,哈哈!HSU28资讯网——每日最新资讯28at.com

HSU28资讯网——每日最新资讯28at.com

1.死锁如何产生

说句难听话,锁一般都很少用到,何况死锁呢?想产生死锁还是有点难的,需要满足2个条件:HSU28资讯网——每日最新资讯28at.com

共享资源同时只能被一个线程使用,如果已经有一个线程占用了资源,其余线程只能等待,直到资源被释放。HSU28资讯网——每日最新资讯28at.com

死锁情况肯定存在多个资源被多个线程争抢的情况。HSU28资讯网——每日最新资讯28at.com

比如线程1持有了资源A,然后去等待获取资源B,线程2持有了资源B,然后等待获取资源A,这样就会形成死锁。HSU28资讯网——每日最新资讯28at.com

2.如何避免死锁

一般有2种方式避免死锁:HSU28资讯网——每日最新资讯28at.com

  • 线程一次性获取需要的全部资源。
  • 获取锁时,增加超时动作。如果在一定的时间内获取不到锁,则释放已经获取的锁。

3.代码实践

/** * 避免死锁,我觉得有2种方式: * 1、线程直接一把头获取所需要的全部锁,不要分步 * 2、线程获取A之后,再去获取B,超时仍未获取到B,则释放A */public class AvoidDeadLock01 {    private static Lock lock1 = new ReentrantLock();    private static Lock lock2 = new ReentrantLock();    public static void acquireLocks(Lock lock1, Lock lock2) {        boolean isLock1Acquired = false;        boolean isLock2Acquired = false;        while (true) {            try {                isLock1Acquired = lock1.tryLock();                isLock2Acquired = lock2.tryLock();            } finally {                if (isLock1Acquired && isLock2Acquired) {                    return;                }                if (isLock1Acquired) {                    lock1.unlock();                }                if (isLock2Acquired) {                    lock2.unlock();                }            }            try {                Thread.sleep(100);            } catch (InterruptedException e) {                throw new RuntimeException(e);            }        }    }    public static void main(String[] args) {        Thread thread1 = new Thread(() -> {            acquireLocks(lock1, lock2);            System.out.println("=====线程1 获取到了2把锁=====");            lock1.unlock();            lock2.unlock();        });        Thread thread2 = new Thread(() -> {            acquireLocks(lock1, lock2);            System.out.println("=====线程2 获取到了2把锁=====");            lock1.unlock();            lock2.unlock();        });        thread1.start();        thread2.start();    }}
public class AvoidDeadLock02 {    private static Lock lock1 = new ReentrantLock();    private static Lock lock2 = new ReentrantLock();    public static void acquireLocks(Lock lock1, Lock lock2) {        boolean isLock1Acquired = false;        boolean isLock2Acquired = false;        try {            while (true) {                isLock1Acquired = lock1.tryLock(200, TimeUnit.MILLISECONDS);                if (isLock1Acquired) {                    isLock2Acquired = lock2.tryLock(200, TimeUnit.MILLISECONDS);                    if (isLock2Acquired) {                        break;                    } else {                        lock1.unlock();                    }                }            }        } catch (InterruptedException e) {            Thread.currentThread().interrupt();        } finally {            if (!isLock1Acquired || !isLock2Acquired) {                if (isLock1Acquired) {                    lock1.unlock();                }                if (isLock2Acquired) {                    lock2.unlock();                }            }        }    }    public static void main(String[] args) {        Thread thread1 = new Thread(() -> {            acquireLocks(lock1, lock2);            System.out.println("=====线程1 获取到了2把锁=====");            lock1.unlock();            lock2.unlock();        });        Thread thread2 = new Thread(() -> {            acquireLocks(lock1, lock2);            System.out.println("=====线程2 获取到了2把锁=====");            lock1.unlock();            lock2.unlock();        });        thread1.start();        thread2.start();    }}

4.出现死锁如何排查

一般出现死锁时,可能会导致CPU、内存等资源消耗过高,导致系统性能下降。也可能导致应用无响应或者假死等等,所以要从多角度进行死锁的排查。HSU28资讯网——每日最新资讯28at.com

首先是用top、df、free等命令查看操作系统的基本情况。然后可以使用jmap、jstack等命令查看JVM线程栈和堆内存的情况。一般出现死锁时,会在线程栈的信息里出现deadlock字样。HSU28资讯网——每日最新资讯28at.com

还可以采用VisualVM、JConsole等工具进行排查。HSU28资讯网——每日最新资讯28at.com

HSU28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-80818-0.htmlJava并发:如何避免死锁

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 构建企业级微服务平台:实现可扩展性、弹性和高效性

下一篇: 这些CSS特性,我知道, 但是 You don't

标签:
  • 热门焦点
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 女孩租房开2小时空调用完100元电费引热议:5级能耗惹不起 月薪过万电费也交不起

    近日,江苏苏州一女孩租房当天充值了100元电费,开着空调不到2小时发现电费已用完。对于为什么这个快,房东表示,电表坏了这种情况很多,之前也遇到过,给租客换
  • 三分钟白话RocketMQ系列—— 如何发送消息

    我们知道RocketMQ主要分为消息 生产、存储(消息堆积)、消费 三大块领域。那接下来,我们白话一下,RocketMQ是如何发送消息的,揭秘消息生产全过程。注意,如果白话中不小心提到相关代
  • 腾讯盖楼,字节拆墙

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之“想重温暴刷深渊、30+技能搭配暴搓到爽的游戏体验吗?一起上晶核,即刻暴打!”曾凭借直播腾讯旗下代理格斗游戏《DNF》一
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己“当家”的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元“人在职场,应该选择什么样的着装?”近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • 8月见!小米MIX Fold 3获得3C认证:支持67W快充

    这段时间以来,包括三星、一加、荣耀等等有不少品牌旗下的最新折叠屏旗舰都得到了不少爆料,而小米新一代折叠屏旗舰——小米MIX Fold 3此前也屡屡被传
  • 信通院:小米、华为等11家应用商店基本完成APP签名及验签工作

    中国信通院表示,目前,小米、华为、OPPO、vivo、360手机助手、百度手机助手、应用宝、豌豆荚和努比亚等9家应用商店,以及抖音和快手2家新型应用分发平
  • 电博会与软博会实现"线下+云端"的双线融合

    在本次“电博会”与“软博会”双展会利好条件的加持下,既可以发挥展会拉动人流、信息流、资金流实现快速交互流动的作用,继而推动区域经济良性发展;又可以聚
Top