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.

  • 相关阅读:
    第七章 第一月:开始 第二周:链接建设(2)
    基础篇 第四节 项目进度计划编辑 之 日历
    VSS2005 使用说明
    删除存储过程
    基础篇 第四节 项目进度计划编辑 之 任务关联性设定
    转载: input 的css技巧
    js: js判断回车键
    一个简单邮件发送类
    转载: php发送邮件原理
    css 小经验: 重构css的优化与技巧
  • 原文地址:https://www.cnblogs.com/yangyongjie/p/14661481.html
Copyright © 2011-2022 走看看