使用信号量限制并发数量

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

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

相关推荐
运筹vivo@16 分钟前
LeetCode 2405. 子字符串的最优划分
c++·算法·leetcode·职场和发展·哈希表
有点。44 分钟前
C++(枚举法一练习题)
开发语言·c++·算法
Klong.k1 小时前
如何避免Bean的线程安全问题
java·开发语言
basketball6161 小时前
C++ 单例模式完全指南:从饿汉式到现代 C++ 的最佳实践
java·c++·单例模式
接着奏乐接着舞1 小时前
【无标题】
开发语言·前端·javascript
iiiiyu1 小时前
集合进阶(Map集合)
java·大数据·开发语言·数据结构·编程语言
玖釉-1 小时前
栈——栈的定义及基本操作
c++·windows·算法·图形渲染
月落归舟1 小时前
并发编程之volatile深度解析(二)
java·开发语言·volatile