线程池的原理分析

Published on with 0 views and 0 comments

  • 线程使用上的问题

new Thread().start();

  1. 线程的频繁创建和销毁
  2. 线程的数量过多,会造成 CPU 资源的开销。
  3. 上下文切换 (消耗 CPU 资源)
  • 池化技术

连接池、对象池、内存池、线程池 。。。

池化技术的核心: 复用

线程池的设计思考

需求: 实现线程的重复使用.

让线程重复使用的唯一方法,就是使线程不结束

通过阻塞队列,实现线程复用

线程池的实现原理分析

线程池实现只需要一个阻塞队列就可以实现,当线程去阻塞队列拿任务的时候,如果阻塞队列没有任务,那么该线程就阻塞在这里。

线程池添加任务的原理

ca7b2f08427a5820d890ccaa739283120220411155541pvw862i.png

线程池如何设置合理的线程数量

IO 密集型 CPU 2core+1
CPU 密集型 CPU +1


标题:线程池的原理分析
作者:cuijianzhe
地址:https://cjzshilong.cn/articles/2022/04/11/1649663914943.html