zoukankan      html  css  js  c++  java
  • 线程死锁问题

    什么是线程死锁,如何解决 ?

    产生死锁的条件有四个:

    1. 互斥条件:所谓互斥就是进程在某一时间内独占资源。 

    2. 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。 

    3. 不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺。 

    4. 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。

      线程死锁是因为多线程访问共享资源,由于访问的顺序不当所造成的,通常是一个线程锁定了一个资源A,而又想去锁定资源B;在另一个线程中,锁定了资源B,而又想去锁定资源A以完成自身的操作,两个线程都想得到对方的资源,而不愿释放自己的资源,造成两个线程都在等待,而无法执行的情况。

    要解决死锁,可以从死锁的四个条件出发,只要破坏了一个必要条件,那么我们的死锁就解决了。在java中使用多线程的时候一定要考虑是否有死锁的问题哦。

      1、按顺序加锁

        上个例子线程间加锁的顺序各不一致,导致死锁,如果每个线程都按同一个的加锁顺序这样就不会出现死锁。

      2、获取锁超时放弃机制

        每个获取锁的时候加上个时限,如果超过某个时间就放弃获取锁之类的。如Lock接口提供的tryLock(long time, TimeUnit unit)方法

      3、死锁检测

        按线程间获取锁的关系检测线程间是否发生死锁,如果发生死锁就执行一定的策略,如终断线程或回滚操作等。

    END.

  • 相关阅读:
    终于有人把MYSQL索引讲清楚了
    计算机基础知识总结与操作系统 PDF 下载
    java电子书python电子书等PDF下载方式
    redis布隆过滤器
    IntelliJ IDEA 2020.1 激活教程,亲测可用
    Another Redis DeskTop Manager一款稳定全新的redis连接工具
    一文吃透redis持久化,妈妈再也不担心我面试过不了!
    ES6 运算符
    If-Else的5种方法从入门到高级示例
    ES6中 的类(class)
  • 原文地址:https://www.cnblogs.com/yangyongjie/p/14661481.html
Copyright © 2011-2022 走看看