死锁的产生 简单代码实现 以及 解决方案

过多的同步可能会造成 相互不释放资源 相互的等待 然后造成死锁

代码如下:

public class SnyTest {

    public static void main(String[] args) {
          Markup markup1 = new Markup(0,"大丫");
        Markup markup2 = new Markup(1,"二丫");
        markup1.start();
        markup2.start();
    }
}

//口红
class Lipstick{

 }

 //镜子
class Mirror{

 }

 //化妆
class Markup extends  Thread{
   static  Lipstick  lipstick = new Lipstick();
   static  Mirror  mirror = new Mirror();
   //选择
     int choice;
     //名字
     String girl;
     public Markup(int choice,String girl){
       this.choice=choice;
       this.girl =girl;
     }

    public void run(){
      //化妆
      markup();
    }

    //相互持有对方的对象锁 ---》可能造成死锁
    private void markup(){
           if(choice ==0){
                synchronized (lipstick){ //获得口红的锁 同时想获取镜子的锁
                    System.out.println(this.girl +"获得口红");

                //一秒后想拥有镜子的锁
               try {
                   Thread.sleep(1000);
               } catch (InterruptedException e) {
                   e.printStackTrace();
               }

               synchronized (mirror){
                   System.out.println(this.girl +"获得镜子");
               }
                }
           }else{
               synchronized (mirror){ //获得镜子的锁 同时想获取口红的锁
                   System.out.println(this.girl +"获得镜子");

               //一秒后想拥有镜子的锁
               try {
                   Thread.sleep(2000);
               } catch (InterruptedException e) {
                   e.printStackTrace();
               }

               synchronized (lipstick){
                   System.out.println(this.girl +"获得口红");
               }
               }
           }

    }


 }

解决方法如下 改进:(不要进行锁嵌套 即可解决 )

private void markup(){
           if(choice ==0){
                synchronized (lipstick) { //获得口红的锁  不要进行锁嵌套
                    System.out.println(this.girl + "获得口红");
                }
                //一秒后想拥有镜子的锁
               try {
                   Thread.sleep(1000);
               } catch (InterruptedException e) {
                   e.printStackTrace();
               }

               synchronized (mirror){
                   System.out.println(this.girl +"获得镜子");
               }
                
           }else{
               synchronized (mirror) { //获得口红的锁 不要进行锁嵌套  
                   System.out.println(this.girl + "获得镜子");
               }
               //一秒后想拥有镜子的锁
               try {
                   Thread.sleep(2000);
               } catch (InterruptedException e) {
                   e.printStackTrace();
               }

               synchronized (lipstick){
                   System.out.println(this.girl +"获得口红");
               }
               
           }

    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值