Java 并发编程学习笔记(2) ----Semaphore

本文详细介绍了Semaphore类中的advanced方法,如availablePermits(), drainPermits(), getQueueLength(), hasQueuedThreads()等,以及它们在并发控制中的应用。同时,探讨了公平与非公平信号量的区别及其对线程调度的影响。

21.一些其他方法

availablePermits()方法,表示返回Semaphore对象中的当前可用许可数,此方法通常用于调试,因为许可数量(通路)可能是实时在改变的。
drainPermits()方法可获取并返回立即可用的所有许可(通路)个数,并将可用许可置为0。

getQueueLength()获取等待许可的线程个数。
hasQueuedThreads()判断有没有线程在等待这个许可。
getQueueLength()和hasQueuedThreads()通常都是在判断当前有没有等待许可的线程信息时使用

22.公平与非公平信号量

有些时候,获取许可的顺序与线程启动的顺序有关,这时信号量就要分为公平与非公平的。
公平信号量是获得所得顺序和线程启动顺序有关,但仅仅是在概率上,不代表 100%能获取。
信号量默认的构造方法是创建非公平信号量(Semaphore semaphore = new Semaphore(8);)。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值