• 线程死锁问题


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

    产生死锁的条件有四个:

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

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

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

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

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

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

      1、按顺序加锁

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

      2、获取锁超时放弃机制

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

      3、死锁检测

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

    END.

  • 相关阅读:
    Windows下开发过程中常用的Linux指令
    flask sqlalchemy实现分页功能
    channel(3) 一 基本定义
    goroutine(2) goroutine同步
    goroutine(1) go的调度器
    go 语言 interface(接口 二)
    go 语言 interface(接口 一)
    go 语言 defer
    go 语言 闭包
    go 语言 函数
  • 原文地址:https://www.cnblogs.com/yangyongjie/p/14661481.html
Copyright © 2020-2023  润新知