请分析此例子为什么会出现死锁?

24 篇文章 0 订阅

程序中若要进行资源共享就要进行同步(synchronized()),但是同步用的过多就会出现死锁的现象!

public class DeadThread implements Runnable {
    Bangjiafang b = new Bangjiafang();
    GeGe g = new GeGe();

    public DeadThread() {
        new Thread(this).start();
        b.say(g);
    }

    @Override
    public void run() {
        // TODO Auto-generated method stub
        g.say(b);
    }

    public static void main(String[] args) {
        new DeadThread();
    }
}

 class Bangjiafang {


    public synchronized void say(GeGe g) {
        System.out.println("给我500W,放你妹");
        g.fun();
    }

    public synchronized void fun() {
        System.out.println("绑架犯得到了500w,放了妹妹");
    }
}

class GeGe {
    public synchronized void say(Bangjiafang b) {
        System.out.println("放妹,给你500w");
        b.fun();
    }

    public synchronized void fun() {
        System.out.println("哥哥救出妹妹,损失了500w");
    }
}

运行后

给我500W,放你妹
放妹,给你500w

绑架犯既没有得到500w,哥哥也没有救出妹妹,双方一直是处于一种等待僵持的状态,即所谓线程死锁。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值