使用信号量限制并发数量

1、限制并发是为了保护有限的资源或防止系统过载。例如:让10个线程同时工作听起来很高效,但如果它们争抢的只是3个坑位的资源(比如数据库连接、CPU核心、网络宽带),结果就是灾难性的。

2、保护有限的物理资源,最典型的例子就是数据库连接池,如果使用互斥锁,让10个线程排队,每次只有一个人拿到锁而连接到整个连接池,就会导致连接池中只有1个连接工作,其他连接处于空闲状态,导致效率低下;而使用计数信号量之后,每次允许3个连接,剩下7个线程排队,一旦有人释放了许可,就允许其它等待的获取该许可,即保护了连接池资源,又实现了最大程度的并发。

相关推荐
jc06201 小时前
6.1云原生之Docker
c++·docker·云原生
糯米团子7492 小时前
Web Worker
开发语言·前端·javascript
我命由我123452 小时前
JavaScript 开发 - 获取函数名称、获取函数参数数量、获取函数参数名称
开发语言·前端·javascript·css·html·html5·js
白晨并不是很能熬夜2 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
简简单单就是我_hehe3 小时前
后端链路追踪局部采集和全量采集配置说明
java·开发语言
北京理工大学软件工程3 小时前
C#111
开发语言·c#
叶子野格4 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
光影少年4 小时前
前端线上屏幕出现卡顿如何排查?
开发语言·前端·javascript·学习·前端框架·node.js
ch3nyuyu4 小时前
静态库和动态库的制作
linux·运维·开发语言