黑马程序员_线程死锁

------- android培训java培训、期待与您交流! ----------

死锁

同步中嵌套同步

  也就是有两个房子,A和B,主人A 拿着B房间的锁,B主人拿着A房间的锁,A拿不到B的锁,就进不去房间

而B拿不到A的锁,也进不去房间,两人相持不下
死锁属于操作系统的概念了……其实很好理解。最经典的例子就是,You first,You first问题。
 一个门,两个“中国人”,都很有礼貌,走碰头了,都想过这个门,两个人都谦让对方先过,结果是,谁也过不去……。

还有就是哲学家问题!说是四个哲学家坐在桌子上等着吃饭,每个人一边一根筷子,四个人四根筷子。
一个人拿到两根筷子的时候才能吃。否则等待…… ,有一种情况就是,四个人,每个人都拿了一根筷子,

  还没有人放手。结果四个人都饿死……

class Lock implements Runnable

 {

    private boolean flag;

    public Lock(boolean flag)

   {

         this.flag=flag;

  }

   public void run()

  {

      if(flag)

       {

           while(true)

          {

               synchronized(MyLock.locka) //a锁中嵌套 b锁

              {

                  System.out.println("if locka");

              synchronized(MyLock.lockb)

                  {

                       System.out.println("if lockb");

                }

            }

          }

        }

      else

       {
       while(true)
     {
               synchronized(MyLock.lockb) //b 锁中嵌套a锁
             {
                   System.out.println("else lockb");

                  synchronized(MyLock.locka)

                  {

                       System.out.println("MyLock.locka");

                  }
               }

          }

       }



   }

}



 class MyLock

 {

   static Object locka=new Object();

    static Object lockb=new Object();

}

 


 public class LockDemo {


  public static void main(String[] args) {

         Thread lock1=new Thread(new Lock(false));

       Thread lock2=new Thread(new Lock(true));

     lock1.start();

      lock2.start();

    }


 

黑马程序员多线程练习题主要包括两个问题。第一个问题是如何控制四个线程在打印log之前能够同时开始等待1秒钟。一种解决思路是在线程的run方法中调用parseLog方法,并使用Thread.sleep方法让线程等待1秒钟。另一种解决思路是使用线程池,将线程数量固定为4个,并将每个调用parseLog方法的语句封装为一个Runnable对象,然后提交到线程池中。这样可以实现一秒钟打印4行日志,4秒钟打印16条日志的需求。 第二个问题是如何修改代码,使得几个线程调用TestDo.doSome(key, value)方法时,如果传递进去的key相等(equals比较为true),则这几个线程应互斥排队输出结果。一种解决方法是使用synchronized关键字来实现线程的互斥排队输出。通过给TestDo.doSome方法添加synchronized关键字,可以确保同一时间只有一个线程能够执行该方法,从而实现线程的互斥输出。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [黑马程序员——多线程10:多线程相关练习](https://blog.csdn.net/axr1985lazy/article/details/48186039)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值