多线程&并发篇---第九篇

系列文章目录


文章目录

  • 系列文章目录
  • 一、产生死锁的四个必要条件?
  • 二、如何避免死锁?
  • 三、线程池核心线程数怎么设置呢?


一、产生死锁的四个必要条件?

  1. 互斥条件:一个资源每次只能被一个线程使用
  2. 请求与保持条件:一个线程因请求资源而阻塞时,对已获得的资源保持不放
  3. 不剥夺条件:进程已经获得的资源,在未使用完之前,不能强行剥夺
  4. 循环等待条件:若干线程之间形成一种头尾相接的循环等待资源关系

二、如何避免死锁?

指定获取锁的顺序,举例如下:

  1. 比如某个线程只有获得A锁和B锁才能对某资源进行操作,在多线程条件下,如何避免死锁?
  2. 获得锁的顺序是一定的,比如规定,只有获得A锁的线程才有资格获取B锁,按顺序获取锁就可
    以避免死锁!!!

三、线程池核心线程数怎么设置呢?

分为CPU密集型和IO密集型
CPU
这种任务消耗的主要是 CPU 资源,可以将线程数设置为 N(CPU 核心数)+1,比

你可能感兴趣的:(死锁)