Java 多线程 - Semaphore

回到顶部(go to top)

总结

1-Semaphore 的构造方法 Semaphore(int permits)接受一个整型的数字, 表示可用的许可证数量

2-线程使用 Semaphore 的 acquire()方法获取一个许可证,使用完之后调用 release()方法归还许可证。还可以用 tryAcquire()方法尝试获取许可证。

 

3-应用场景 Semaphore 可以用于做流量控制,特别是公用资源有限的应用场景,比如数据库连接。

回到顶部(go to top)

Semaphore 详解

Semaphore(信号量)是用来控制同时访问特定资源的线程数量,它通过协 调各个线程,以保证合理的使用公共资源。应用场景 Semaphore 可以用于做流 量控制,特别是公用资源有限的应用场景,比如数据库连接。假如有一个需求, 要读取几万个文件的数据,因为都是 IO 密集型任务,我们可以启动几十个线程 并发地读取,但是如果读到内存后,还需要存储到数据库中,而数据库的连接数 只有 10 个,这时我们必须控制只有 10 个线程同时获取数据库连接保存数据,否 则会报错无法获取数据库连接。这个时候,就可以使用 Semaphore 来做流量控 制。。Semaphore 的构造方法 Semaphore(int permits)接受一个整型的数字, 表示可用的许可证数量。Semaphore 的用法也很简单,首先线程使用 Semaphore 的 acquire()方法获取一个许可证,使用完之后调用 release()方法归还许可证。还 可以用 tryAcquire()方法尝试获取许可证。

Semaphore 还􏰀供一些其他方法,具体如下。

•intavailablePermits():返回此信号量中当前可用的许可证数。

•intgetQueueLength():返回正在等待获取许可证的线程数。

•booleanhasQueuedThreads():是否有线程正在等待获取许可证。

•voidreducePermit(s intreduction):减少reduction个许可证,是个protected 方法。

•Collection getQueuedThreads():返回所有等待获取许可证的线程集合,是 个 protected 方法。

 

 

 

posted on   frank_cui  阅读(183)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

levels of contents
点击右上角即可分享
微信分享提示