首页 > 其他分享 >线程池原理

线程池原理

时间:2024-10-31 14:42:26浏览次数:1  
标签:工作 队列 处理 任务 线程 原理 多线程

线程池是一种多线程处理方式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。如果某个线程在托管代码中空闲(如正在等待某个事件),则线程池将插入另一个辅助线程来使所有处理器保持繁忙。如果所有线程池线程都始终保持繁忙,但是队列中包含挂起的工作,那么线程池将在一段时间后创建另一个辅助线程但是线程的数目永远不会超过最大值。超过最大值的线程可以排队,但是他们要等到其他线程完成后才可以启动。

线程池的组成主要分为3个部分,这三个部分配合工作就可以得到一个完整的线程池:

(1)任务队列:存储需要处理的任务,由工作的线程来处理这些任务

  1.通过线程池提供的API函数,将一个待处理的任务添加到任务队列,或者从任务队列中删除

  2.已处理的任务会被从任务队列中删除

  3.线程池的使用者,也就是调用线程池函数往任务队列中添加任务的线程就是生产者线程

(2)工作的线程(任务队列任务的消费者)有多个

  1.线程池中维护了一定数量的工作线程,他们的作用是不停的读任务队列,从里边取出任务并处理

  2.工作的线程相当于是任务队列的消费者角色

  3.如果任务队列为空,工作线程将会被阻塞

  4.如果阻塞之后有了新的任务,由生产者将阻塞解除,工作线程开始工作。

  (3) 管理者线程(不处理任务队列中的任务)1个

   它的任务是周期性的对任务队列中的任务数量以及处于忙状态的工作线程个数进行检测

        当任务过多的时候,可以适当创建一些新的工作线程。

        当任务过少的时候,可以适当的销毁一些新的工作线程。

 

标签:工作,队列,处理,任务,线程,原理,多线程
From: https://www.cnblogs.com/huwy-123/p/18517793

相关文章

  • 多线程在打包工具中的运用
    我们是袋鼠云数栈UED团队,致力于打造优秀的一站式数据中台产品。我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值。本文作者:UED团队现代操作系统都是「多任务」的,也就是操作系统可以「并发」处理多个任务,比如可以在浏览页面的时候同时播放音乐。但是,一般来说我......
  • React 中useState 原理
    useState是React中的一个Hook,用于在函数组件中添加状态管理。理解useState的原理有助于更好地掌握React的状态管理机制。1.基本概念状态(State):状态是组件内部的数据,可以影响组件的渲染。每当状态更新时,组件会重新渲染以反映新的状态。useState的作用:通过useS......
  • 小白手把手教学用spring框架实现mybatis和mysql以及工作原理
    Maven_Mybatis_Mysql什么是MybatisMyBatis是一款优秀的持久层框架,它支持自定义SQL、存储过程以及高级映射。MyBatis免除了几乎所有的JDBC代码以及设置参数和获取结果集的工作。MyBatis可以通过简单的XML或注解来配置和映射原始类型、接口和JavaPOJO(PlainOldJavaObj......
  • FMC子卡设计原理图:FMC229-8路DAC&2路ADC 的FMC子卡
    FMC229-8路DAC&2路ADC的FMC子卡 一、板卡概述   FMC229-8路DAC&2路ADC的FMC子卡是公司自主研发的8路250MspsDA16bit,2路AD 250Msps 14bitAD板卡。板卡采用标准FMC子卡架构,可方便的与其他FMC板卡实现高速互联,可广泛用于高频模拟信号采集等场......
  • RAID篇:理解磁盘阵列原理并配置RAID5
    RAID(独立磁盘阵列冗余):一种存储技术,通过将两个或多个硬盘驱动器(HDD)或固态硬盘(SSD)合并成一个协调的存储单元或阵列,从而创建数据丢失的故障安全机制。RAID0:条带化(数据分块),没有冗余,提供较高的读写性能。适用场景:需要高性能而不关心数据冗余的场景(视频编辑和处理、大型数据库应......
  • 多线程编程 Linux环境
    进程和线程相同点:都是参与时间片轮转的任务,都有5个状态不同点:线程不能独立存在,只能隶属于创建它的进程进程实际上是线程的容器,任何进程至少包含一个称为主线程的线程,执行main函数所在的执行序列,这个线程是系统为进程自动创建而其余线程则进程通过调用相关函数来创建进......
  • 数据库原理实践2
    实验二:C/S结构的数据库编程(6学时)【实验目的】学会通过ADO.NET访问数据库,熟悉使用ADO.NET技术进行C/S结构的数据库应用程序的设计,通过ADO.NET接口对数据库进行操作。【实验环境】实验环境:Windows11、MicrosoftVisualStudio2022、SQLServer2024【实验任务与结......
  • C++多线程应用
    一个进程就是一个程序,一个程序里不止一个功能,每个功能的实现就可以交给一个线程去完成。一个进程就像是一个工程,这个工程里,有设计,有监理,有施工,就相当于三个线程,各干各的又相互配合。https://cplusplus.com/reference/thread/thread/thread/是C++的官方参考,个人觉得比较权威,比经......
  • 【操作系统】1.进程和线程
    1.进程(Process)定义:进程是操作系统资源分配的基本单位,一个进程包含了程序的代码、数据、文件、内存等资源。每个进程之间都是独立的,拥有独立的地址空间。特性:独立性:每个进程之间是独立的,不能直接访问其他进程的内存空间。资源占用:进程会占用较多的系统资源,例如内存、文件描......
  • Linux系统基础-多线程超详细讲解(3)_线程互斥同步和条件变量
    个人主页:C++忠实粉丝欢迎点赞......