C# SemaphoreSlim简单介绍
C# SemaphoreSlim简单介绍
当多个任务或线程并行运行时,难以避免的对某些有限的资源进行并发的访问。可以考虑使用信号量来进行这方面的控制(System.Threading.Semaphore)是表示一个Windows内核的信号量对象。如果预计等待的时间较短,可以考虑使用SemaphoreSlim,它带来的开销更小。如果需要有跨进程或AppDomain的同步时,可以考虑使用Semaphore.Semaphore是取得的Windows内核的信号量,所以在整个系统中是有效的。它主要的接口是Release和WaitOne,使用的方式和SemaphoreSlim是一致的
该类可以限制同时访问同一资源的线程数量。
static void Main(string[] args)
{
SemaphoreSlim slim = new SemaphoreSlim(4);//允许最多4个线程
foreach(int index in Enumerable.Range(1, 100))
{
Task.Run(() => {
slim.Wait();
Console.WriteLine($"这是{index}");
Thread.Sleep(2000);//等待2秒
slim.Release();
});
}
Console.ReadKey();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
2018-10-15 禅道使用规范