0

0

c# 如何限制并发任务的数量 c# SemaphoreSlim限流

煙雲

煙雲

发布时间:2026-01-26 10:24:36

|

738人浏览过

|

来源于php中文网

原创

SemaphoreSlim 是 C# 限流最常用选择,因其轻量、异步友好、专为 await 设计,限制同时进入临界区的任务数而非 Task 总数;需在共享作用域初始化且初始计数非零,必须用 await WaitAsync() 和 try/finally 或 await using 确保 Release() 执行;常见错误包括释放次数不匹配、未 await、方法内新建实例;它适用于任意 I/O 异步操作,而 ParallelOptions.MaxDegreeOfParallelism 仅对 CPU 绑定同步循环有效。

c# 如何限制并发任务的数量 c# semaphoreslim限流

为什么 SemaphoreSlim 是 C# 限流最常用的选择

因为它是轻量、异步友好的信号量实现,专为 await 场景设计。相比 Monitorlock,它不会阻塞线程;相比 Task.Run + 队列手动调度,它省去大量协调逻辑。关键点在于:它限制的是「同时进入临界区的任务数」,不是「已创建的 Task 总数」。

如何正确初始化和使用 SemaphoreSlim 实现并发控制

必须在共享作用域(如类字段)中初始化一次,且初始计数不能为 0(否则所有 WaitAsync() 都会挂起)。典型用法是包裹实际耗时操作,而非仅包裹 Task.Run

  • new SemaphoreSlim(5) 表示最多 5 个任务可同时执行,第 6 个会等待前一个 Release()
  • 务必用 await semaphore.WaitAsync() 而非 Wait(),否则可能死锁或线程饥饿
  • 必须确保 Release() 总被执行,推荐用 try/finallyusing(C# 12+ 支持 await using
private readonly SemaphoreSlim _semaphore = new SemaphoreSlim(3);

public async Task FetchDataAsync(string url) { await _semaphore.WaitAsync(); try { return await _httpClient.GetStringAsync(url); } finally { _semaphore.Release(); } }

常见踩坑:释放次数不匹配、未 await、跨作用域复用

最典型的错误是 Release() 调用次数多于 WaitAsync(),导致计数溢出,后续限流失效;或者忘记 await 导致同步阻塞;还有把 SemaphoreSlim 声明在方法内,每次调用都新建,完全不起限流作用。

通义视频
通义视频

通义万相AI视频生成工具

下载
  • 错误:semaphore.Release(2) 但只 WaitAsync() 了一次 → 计数变 4,下次允许 4 个并发
  • 错误:semaphore.WaitAsync().GetAwaiter().GetResult() → 同步等待,UI 线程或 ASP.NET 同步上下文可能死锁
  • 错误:在方法里写 var s = new SemaphoreSlim(1) → 每次调用都是新实例,无共享控制

ParallelOptions.MaxDegreeOfParallelism区别在哪

Parallel.ForEach 中的 MaxDegreeOfParallelism 只控制 Parallel 内部线程调度,不适用于 async/await 方法;而 SemaphoreSlim 是纯逻辑门控,对任何 Task 都有效,包括 HTTP 调用、数据库查询、文件读写等 I/O 异步操作。

  • Parallel.ForEach(..., new ParallelOptions { MaxDegreeOfParallelism = 4 }):仅对 CPU 绑定的同步循环生效
  • SemaphoreSlim:能精准约束 HttpClient 并发请求数、EF Core SaveChangesAsync 并发数等真实 I/O 场景
  • 混合场景(如并行发起多个异步请求):仍需 SemaphoreSlimParallel 在这里基本没用

真正难的不是加一行 WaitAsync(),而是确认哪些操作确实该被纳入同一把锁——比如是否要把日志写入、缓存更新也计入并发配额,这取决于你的资源瓶颈点在哪。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

71

2025.12.04

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

502

2023.08.10

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

356

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2078

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

348

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

325

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

411

2023.10.16

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

4

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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