SemaphoreSlim 是 C# 中专为异步设计的轻量信号量,通过 WaitAsync() 和 Release() 控制并发,需用 try/finally 确保释放,不支持 using,适用于单进程内限流。

SemaphoreSlim 是 C# 中轻量级的信号量实现,专为异步场景设计,适合控制并发访问资源的线程/任务数量。它比传统的 Semaphore 更高效(不依赖操作系统内核),且原生支持 async/await。
构造函数接收两个参数:初始可进入数(通常等于最大并发数)、最大允许数。
var semaphore = new SemaphoreSlim(3, 3);
new SemaphoreSlim(0, 3),则初始无人能进入,需手动 Release() 才能开始务必用 await WaitAsync() 获取许可,用 Release() 归还(不能用 await ReleaseAsync(),它不存在)。
await semaphore.WaitAsync();
try
{
// 执行受控操作,如调用 API、处理文件等
await DoWorkAsync();
}
finally
{
semaphore.Release(); // 必须确保执行到
}using —— SemaphoreSlim 不实现 IDisposable(仅当需要释放底层资源时才调用 Dispose(),一般不用)catch 块外直接 Release(),否则异常时会漏释放,导致许可永久丢失常见需求:启动 100 个 HTTP 请求,但只允许最多 5 个并发。
WaitAsync 控制节奏var tasks = urls.Select(async url =>
{
await semaphore.WaitAsync();
try
{
return await client.GetStringAsync(url);
}
finally
{
semaphore.Release();
}
});
await Task.WhenAll(tasks);Chunk() + Task.WhenAll 嵌套WaitAsync() 可传入 CancellationToken,支持取消等待(比如超时或用户中止)CurrentCount 属性可读取当前剩余许可数(仅作监控,非原子判断依据)Wait() 阻塞等待 —— 容易引发死锁,尤其在 UI 或 ASP.NET 同步上下文中SemaphoreSlim 不适用,得换 Semaphore 或分布式方案(如 Redis 信号量)基本上就这些。SemaphoreSlim 不复杂但容易忽略释放和异常路径,只要守好“try/finally + Release”这个模式,就能稳稳控住并发量。
以上就是C#怎么使用SemaphoreSlim C#限制并发线程数量方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号