线程死锁的概念及其解决方法

“死锁”指的是:

多个线程各自占有一些共享资源,并且互相等待其他线程占有的资源才能进行,而导致两个或者多个线程都在等待对方释放资源,都停止执行的情形。

某一个同步块需要同时拥有“两个以上对象的锁”时,就可能会发生“死锁”的问题。

比如,“化妆线程”需要同时拥有“镜子对象”、“口红对象”才能运行同步块。那么,实际运行时,“小丫的化妆线程”拥有了“镜子对象”,“大丫的化妆线程”拥有了“口红对象”,都在互相等待对方释放资源,才能化妆。这样,两个线程就形成了互相等待,无法继续运行的“死锁状态”。

 下面是案例的代码演示

/**
 * 口红类
 */
class Lipstick{

}


/**
 * 镜子类
 */
class Mirror{

}


/**
 * 化妆线程类
 */
class Makeup extends Thread{
      private int flag; //flag=0:拿着口红。flag!=0:拿着镜子
      private String girlName;
      static Lipstick lipstick = new Lipstick();
      static Mirror mirror = new Mirror();


      public Makeup(int flag,String girlName){
            this.flag = flag;
            this.girlName = girlName;
      }

      @Override
      public void run() {
      this.doMakeup();
       }
      /**
       * 开始化妆
       */
      public void doMakeup(){
            if(flag == 0){
            synchronized (lipstick){
            System.out.println(this.girlName+" 拿着口红");
            try {
            Thread.sleep(1000);
            } catch (InterruptedException e) {
            e.printStackTrace();
            }
            synchronized (mirror){
                System.out.println(this.girlName+" 拿着镜子");
            }
     }
}else{
      synchronized (mirror){
            System.out.println(this.girlName+" 拿着镜子");
            try {
              Thread.sleep(2000);
             } catch (InterruptedException e) {
              e.printStackTrace();
             }
            synchronized (lipstick){
              System.out.println(this.girlName+" 拿着口红");
             }
           }
         }
    }
}

public class DeadLockThread {
  public static void main(String[] args) {
    new Makeup(0,"大丫").start();
    new Makeup(1,"小丫").start();
   }
}

上市代码会出现一直运行无法结束的状态,解决方法即是不能做synchronized嵌套,改动如下:

注意synchronized的位置变化:

/**
 * 口红类
 */
class Lipstick{

}


/**
 * 镜子类
 */
class Mirror{

}


/**
 * 化妆线程类
 */
class Makeup extends Thread{
    private int flag; //flag=0:拿着口红。flag!=0:拿着镜子
    private String girlName;
    static Lipstick lipstick = new Lipstick();
    static Mirror mirror = new Mirror();


    public Makeup(int flag,String girlName){
        this.flag = flag;
        this.girlName = girlName;
    }

    @Override
    public void run() {
        this.doMakeup();
    }
    /**
     * 开始化妆
     */
    public void doMakeup(){
        if(flag == 0){
            synchronized (lipstick){
                System.out.println(this.girlName+" 拿着口红");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            synchronized (mirror){
                System.out.println(this.girlName+" 拿着镜子");
            }
        }else{
            synchronized (mirror){
                System.out.println(this.girlName+" 拿着镜子");
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            synchronized (lipstick){
                System.out.println(this.girlName+" 拿着口红");
            }
        }
    }
}

public class DeadLockThread {
    public static void main(String[] args) {
        new Makeup(0,"大丫").start();
        new Makeup(1,"小丫").start();
    }
}

经过修改后代码正常运行。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值