首页 > Java > java教程 > 正文

Java中Semaphore限制并发数量

P粉602998670
发布: 2025-09-22 23:26:01
原创
904人浏览过
Semaphore是Java中用于控制并发线程数量的同步工具,通过维护许可数量限制同时访问资源的线程数。线程需调用acquire()获取许可,执行完后调用release()释放许可;若无可用许可则阻塞等待。示例中创建含3个许可的Semaphore,确保最多3个线程并发执行任务,其余线程等待。支持公平与非公平模式,默认为非公平,公平模式按FIFO顺序分配许可。适用于数据库连接池、硬件资源访问控制和限流场景,有效保护系统资源。

java中semaphore限制并发数量

Semaphore 是 Java 并发包(java.util.concurrent)中提供的一种同步工具,用来控制同时访问特定资源的线程数量。它通过维护一组许可(permits)来实现对并发线程数的限制。当线程想要执行受 Semaphore 保护的代码时,必须先获取一个许可;如果当前没有可用许可,线程就会被阻塞,直到有其他线程释放许可为止。

Semaphore 的基本原理

Semaphore 内部维护一定数量的许可。你可以把它想象成停车场的车位:如果停车场有 3 个车位(即 3 个许可),最多只能有 3 辆车(线程)同时进入。第 4 辆车必须等待,直到有车离开(释放许可)。

主要方法包括:

  • acquire():线程尝试获取一个许可,如果没有可用许可,则阻塞等待。
  • acquire(int permits):一次获取多个许可。
  • release():释放一个许可,将其还给信号量,可能唤醒等待中的线程。
  • release(int permits):释放多个许可。
  • availablePermits():返回当前可用的许可数。

限制并发线程数量的使用示例

假设我们希望最多允许 3 个线程同时执行某个操作,比如访问数据库或调用外部接口,可以使用 Semaphore 来实现:

立即学习Java免费学习笔记(深入)”;

import java.util.concurrent.Semaphore;

public class SemaphoreExample {
    // 定义一个拥有3个许可的信号量
    private static final Semaphore semaphore = new Semaphore(3);

    public static void main(String[] args) {
        for (int i = 1; i <= 5; i++) {
            new Thread(() -> {
                try {
                    System.out.println(Thread.currentThread().getName() + " 尝试获取许可...");
                    semaphore.acquire(); // 获取许可
                    System.out.println(Thread.currentThread().getName() + " 获得许可,开始执行任务");

                    // 模拟任务执行
                    Thread.sleep(2000);

                    System.out.println(Thread.currentThread().getName() + " 任务完成,释放许可");
                } catch (InterruptedException e) {
                    Thread.currentThread().interrupt();
                } finally {
                    semaphore.release(); // 释放许可
                }
            }, "线程-" + i).start();
        }
    }
}
登录后复制

在这个例子中,尽管启动了 5 个线程,但只有 3 个能同时运行。第 4 和第 5 个线程会等待,直到前面的线程调用 release() 释放许可后才能继续执行。

商汤商量
商汤商量

商汤科技研发的AI对话工具,商量商量,都能解决。

商汤商量 36
查看详情 商汤商量

公平性与非公平模式

Semaphore 支持公平和非公平两种模式:

  • 非公平模式(默认):线程获取许可时不考虑等待顺序,可能会导致某些线程长时间得不到许可。
  • 公平模式:按照 FIFO 顺序分配许可,等待最久的线程优先获得许可。

创建公平的 Semaphore:

Semaphore fairSemaphore = new Semaphore(3, true);
登录后复制

适用场景

Semaphore 特别适合用于资源池化管理,例如:

  • 限制数据库连接数
  • 控制对有限硬件资源的访问(如打印机
  • 防止过多线程同时请求远程服务导致系统过载

它不关心是哪个线程获取了许可,只关注数量限制,因此非常适合做“限流”用途。

基本上就这些。Semaphore 提供了一种轻量且灵活的方式控制并发访问数量,合理使用可以在高并发场景下有效保护系统资源。

以上就是Java中Semaphore限制并发数量的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号