半同步/半反应堆线程池

28 篇文章 2 订阅
25 篇文章 2 订阅

一、什么是线程池
线程池是服务器预先创建的一组线程,这些线程运行着相同的代码,并具有相同的属性。当有新的任务到来的时候,主线程通过某种方式选择线程池中的某一个线程来为之服务,服务完之后又放回线程池中。

二、为什么要有线程池
相比于动态创建线程来说,线程池可以提高速度。因为线程的创建和销毁是需要时间的,如果我们预先创建好,用完之后再回收的话,则会节省不少时间。一般线程池中线程的数量和CPU的数量相差不多,不然的话会导致系统在线程间切换上花费不少时间。

三、半同步/半反应堆线程池实现
半同步/半反应堆线程池原理:
这里写图片描述

主线程和工作线程之间通过一个共享的工作队列来同步,工作线程睡眠在工作队列上。当有新的任务到来时,主线程将新的任务添加到工作队列中。这将唤醒正在等待任务的工作线程,不过只有一个工作线程会获得新任务的”接管权”,他可以从工作队列中取出任务并执行。而其他的工作线程则继续睡眠在工作队列上。
由于主线程和工作线程之间有一个工作队列,所以主线程和工作线程之间没有耦合性,主线程往工作队列中插入任务,睡眠的工作线程通过竞争来取得任务并执行它。

线程池源码

四、实例
实现线程池版本的web服务器:
线程池版web服务器

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页
评论

打赏作者

午饭要阳光

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值