Semaphore用于控制并发线程数,通过acquire获取许可、release释放许可,确保最多n个线程访问资源,适用于限流与资源池管理,需注意公平性选择、finally中释放许可及避免中断处理遗漏。

在Java并发编程中,Semaphore 是一个非常有用的工具类,位于 java.util.concurrent 包下,主要用于控制同时访问某一资源的线程数量。它通过维护一组许可证(permits)来实现对资源的限制,适合用于限流、资源池管理等场景。
Semaphore可以看作是一个信号灯,用来控制可同时运行的线程数。当一个线程想要访问共享资源时,需要先获取一个许可(acquire),如果当前没有可用许可,线程就会被阻塞,直到其他线程释放许可(release)。
关键点:
假设我们有一个服务接口,最多只允许3个线程同时调用,可以用Semaphore进行控制:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.Semaphore;
public class ServiceWithSemaphore {
private final Semaphore semaphore = new Semaphore(3); // 最多3个并发
public void handleRequest() throws InterruptedException {
semaphore.acquire(); // 获取许可
try {
System.out.println(Thread.currentThread().getName() + " 开始处理任务");
Thread.sleep(2000); // 模拟耗时操作
System.out.println(Thread.currentThread().getName() + " 完成任务");
} finally {
semaphore.release(); // 释放许可
}
}
public static void main(String[] args) {
ServiceWithSemaphore service = new ServiceWithSemaphore();
for (int i = 0; i < 10; i++) {
new Thread(() -> {
try {
service.handleRequest();
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
}
}, "Thread-" + i).start();
}
}
}
在这个例子中,尽管启动了10个线程,但每次只有3个能真正进入执行状态,其余线程会等待许可释放。
Semaphore不仅仅用于简单的并发数控制,还可以应用于多种实际场景:
使用建议:
使用Semaphore时容易忽略以下几点:
基本上就这些。Semaphore是一个轻量且灵活的并发控制工具,合理使用可以在不增加复杂性的前提下有效控制系统负载。关键是理解其许可模型,并在合适的场景中应用。不复杂但容易忽略细节。
以上就是在Java中如何使用Semaphore控制并发访问_Semaphore类实践经验的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号