Java教程

Java多线程-死锁的出现和解决,彻底剖析JVM类加载机制系列

本文主要是介绍Java多线程-死锁的出现和解决,彻底剖析JVM类加载机制系列,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
  • 什么是死锁?

    死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放.由于线程被无限期地阻塞,因此程序不能正常运行.形象的说就是:一个宝藏需要两把钥匙来打开,同时间正好来了两个人,他们一人一把钥匙,但是双方都再等着对方能交出钥匙来打开宝藏,谁都没释放自己的那把钥匙.就这样这俩人一直僵持下去,直到开发人员发现这个局面.

    导致死锁的根源在于不适当地运用“synchronized”关键词来管理线程对特定对象的访问.“synchronized”关键词的作用是,确保在某个时刻只有一个线程被允许执行特定的代码块,因此,被允许执行的线程首先必须拥有对变量或对象的排他性访问权.当线程访问对象时,线程会给对象加锁,而这个锁导致其它也想访问同一对象的线程被阻塞,直至第一个线程释放它加在对象上的锁.

    对synchronized不太了解的话请点击[这里](

)

  • 举个例子

    死锁的产生大部分都是在你不知情的时候.我们通过一个例子来看下什么是死锁.

    1.synchronized嵌套.

    synchronized关键字可以保证多线程再访问到synchronized修饰的方法的时候保证了同步性.就是线程A访问到这个方法的时候线程B同时也来访问这个方法,这时线程B将进行阻塞,等待线程A执行完才可以去访问.这里就要用到synchronized所持有的同步锁.具体来看代码:

    //首先我们先定义两个final的对象锁.可以看做是共有的资源.
     final Object lockA = new Object();
     final Object lockB = new Object();
    //生产者A
      class  ProductThreadA implements Runnable{
          @Override
          public void run() {
    //这里一定要让线程睡一会儿来模拟处理数据 ,要不然的话死锁的现象不会那么的明显.这里就是同步语句块里面,首先获得对象锁lockA,然后执行一些代码,随后我们需要对象锁lockB去执行另外一些代码.
              synchronized (lockA){
              //这里一个log日志
                  Log.e("CHAO","ThreadA lock  lockA");
                  try {
                      Thread.sleep(2000);
                  } catch (InterruptedException e) {
                      e.printStackTrace();
                  }
                  synchronized (lockB){
                   //这里一个log日志
                      Log.e("CHAO","ThreadA lock  lockB");
                      try {
                          Thread.sleep(2000);
                      } catch (InterruptedException e) {
                          e.printStackTrace();
                      }
    
                  }
              }
          }
      }
      //生产者B
      class  ProductThreadB implements Runnable{
      //我们生产的顺序真好好生产者A相反,我们首先需要对象锁lockB,然后需要对象锁lockA.
          @Override
          public void run() {
              synchronized (lockB){
               //这里一个log日志
                  Log.e("CHAO","ThreadB lock  lockB");
                  try {
                      Thread.sleep(2000);
                  } catch (InterruptedException e) {
                      e.printStackTrace();
                  }
    
    
    
这篇关于Java多线程-死锁的出现和解决,彻底剖析JVM类加载机制系列的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!