信号量Semaphore用于控制并发访问资源的线程数,通过acquire()获取许可、release()释放许可,支持公平与非公平模式,常用于限流、资源池等场景,需注意异常时释放许可以避免泄漏。

Semaphore(信号量)是Java并发包java.util.concurrent中提供的一个同步工具,用来控制同时访问某一资源的线程数量。它通过维护一组许可(permits)来实现:线程在访问资源前必须先获取许可,使用完后释放许可。如果当前没有可用许可,线程将被阻塞,直到有其他线程释放许可为止。
Semaphore有两种模式:公平和非公平。
创建Semaphore时指定许可数量和是否公平:
// 允许最多3个线程并发访问,非公平模式 Semaphore semaphore = new Semaphore(3); // 公平模式 Semaphore fairSemaphore = new Semaphore(3, true);
控制并发的核心是acquire()和release()方法:
立即学习“Java免费学习笔记(深入)”;
示例:限制数据库连接池最多3个连接
class DatabaseConnection {
    private final Semaphore semaphore = new Semaphore(3);
    public void connect() throws InterruptedException {
        semaphore.acquire(); // 获取许可
        try {
            System.out.println(Thread.currentThread().getName() + " 正在使用数据库连接");
            Thread.sleep(2000); // 模拟操作
        } finally {
            System.out.println(Thread.currentThread().getName() + " 释放连接");
            semaphore.release(); // 释放许可
        }
    }
}
Semaphore适合用于资源有限的场景:
测试代码:
public class SemaphoreDemo {
    public static void main(String[] args) {
        DatabaseConnection db = new DatabaseConnection();
        for (int i = 1; i <= 5; i++) {
            new Thread(() -> {
                try {
                    db.connect();
                } catch (InterruptedException e) {
                    Thread.currentThread().interrupt();
                }
            }, "Thread-" + i).start();
        }
    }
}
输出会显示每次最多只有3个线程能同时执行connect()方法。
使用Semaphore时要注意以下几点:
基本上就这些。Semaphore是一个轻量且有效的并发控制工具,合理使用可以很好地保护共享资源不被过度访问。
以上就是在Java中如何通过Semaphore控制并发访问数量的详细内容,更多请关注php中文网其它相关文章!
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号