当前位置: 首页 > article >正文

线程池的理解

线程池

线程池本质上是一种池化技术,而池化技术是一种资源复用的思想,比较常见的有连接池、内存池、对象池。 而线程池里面复用的是线程资源,它的核心设计目标,有两个:
  • 减少线程的频繁创建和销毁带来的性能开销,因为线程创建会涉及到 CPU 上下文切换、内存分配等工作。
  • 线程池本身会有参数来控制线程创建的数量,这样就可以避免无休止的创建线程带来的资源利用率过高的问题,起到了资源保护的作用。

工作线程

对于线程池里面的线程复用技术。因为线程本身并不是一个受控的技术,也就是说线程的生命周期是由任务运行的状态决定的,无法人为控制。 所以为了实现线程的复用,线程池里面用到了阻塞队列,简单来说就是线程池 里面的工作线程处于一直运行状态,它会从阻塞队列中去获取待执行的任务,一旦队列空了,那这个工作线程就会被阻塞,直到下次有新的任务进来。 也就是说,工作线程是根据任务的情况实现阻塞和唤醒,从而达到线程复用的目的。 最后,线程池里面的资源限制,是通过几个关键参数来控制的,分别是核心线程数、最大线程数。 核心线程数表示默认长期存在的工作线程,而最大线程数是根据任务的情况动态创建的 线程,主要是提高阻塞队列中任务的 处理效率。

http://www.kler.cn/a/106914.html

相关文章:

  • 设计模式-单例模式
  • nuiapp在APP中的.nvue页面中使用webview展示空白的问题
  • 蓝桥杯刷题第二天——背包问题
  • 【tailscale 和 ssh】当服务器建立好节点,但通过客户端无法通过 ssh 连接
  • 分频器code
  • 电脑风扇声音大怎么办? 原因及解决方法
  • 字符串与基本类型之间的相互转换
  • vue2组件库-上传组件
  • 框架安全-CVE 复现SpringStrutsLaravelThinkPHP漏洞复现
  • Peter算法小课堂—归并排序
  • 【Linux】安装与配置虚拟机及虚拟机服务器坏境配置与连接
  • LibreOffice编辑excel文档如何在单元格中输入手动换行符
  • 如何中断一个正在运行的线程?
  • Java关于实例对象调用静态变量和静态方法问题
  • ue5 右击.uproject generator vs project file 错误
  • VM虚拟机的安装与配置及操作系统的安装
  • [RISC-V]verilog
  • DeepSpeed: 大模型训练框架 | 京东云技术团队
  • 【DOCKER】
  • 一个简单的注册页面,如有错误请指正(2.css)
  • “穷”用英语怎么说?柯桥成人英语培训
  • 数据结构与算法之排序: 归并排序 (Javascript版)
  • Jenkins入门级安装部署
  • 轻量封装WebGPU渲染系统示例<1>-彩色三角形(源码)
  • MySQL存储过程与函数
  • SOLIDWORKS® 2024 新功能 - SIMULATION