线程池的原理分析

2023-07-18 18:50:47 浏览数 (1)

线程使用上的问题

new Thread().start();

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

连接池、对象池、内存池、线程池 。。。 池化技术的核心: 复用

线程池的设计思考

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

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

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

线程池的实现原理分析

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

线程池添加任务的原理
线程池如何设置合理的线程数量

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

0 人点赞