DeadLock死锁问题

死锁是什么?

Java中死锁是多个线程互相持有对方需求的锁却又不肯释放掉自己锁持有的锁。所造成的程序暂停。
就如同两个人分别拿枪指着对方的脑袋,并要求对方先放下枪,自己才肯放下枪,如果没有一个人做出让步,则僵持不下的状态会一直持续下去。

死锁Demo

package com.design;

public class DeadLockDemo extends Thread {
    public static void main(String[] args) {
        Children ming = new Children("小明");
        Children hong = new Children("小红");
        new Thread(
                ()->{
                    synchronized (Children.bread)
                    {
                        ming.eat();
                        try {
                            Thread.sleep(1000);
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                        synchronized (Children.milk)
                        {
                            ming.drink();
                        }
                    }
                }
        ).start();
        new Thread(
                ()->{
                    synchronized (Children.milk)
                    {
                        hong.eat();
                        try {
                            Thread.sleep(1000);
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                        synchronized (Children.bread)
                        {
                            hong.drink();
                        }
                    }
                }
        ).start();
    }
}

class Children {
    static String milk = "牛奶";
    static String bread = "面包";
    String name;

    public Children(String name) {
        this.name = name;
    }

    void eat() {
        System.out.println(name + "正在吃" + bread);
    }

    void drink() {
        System.out.println(name + "正在喝" + milk);
    }

}

在上面的例子中,我们声明了两个静态变量milk和bread,以保证变量的唯一性。
我们小明先取得面包锁进行吃,让小红先取得牛奶锁进行喝。然后让两个线程分别休眠1秒钟,两线程休眠过后。小明要获取牛奶锁才能完成吃释放掉面包锁,而小红要获取面包锁才能完成喝释放掉牛奶锁。二者互相等待,谁都不肯释放掉当前锁。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值