C#中的信号量---Semaphore
emaphore是System.Threading下的类,限制可同时访问某一资源或资源池的线程数。
常用构造方法
https://msdn.microsoft.com/zh-cn/library/e1hct27h(v=vs.110).aspx
public Semaphore( int initialCount, int maximumCount )
参数
- initialCount
- Type: System.Int32
可以同时授予的信号量的初始请求数。
- maximumCount
- Type: System.Int32
可以同时授予的信号量的最大请求数。
示例代码
class Program { static Semaphore sema = new Semaphore(1,1); static void Main(string[] args) { for (int i = 0; i < 3; i++) { var thread = new Thread(Test) { Name = $"Thread{ i }" }; thread.Start(); } Console.ReadKey(); } static void Test() { sema.WaitOne(); for (int i = 0; i < 3; i++) { Console.WriteLine($"ThreadName:{ Thread.CurrentThread.Name} i:{i}"); Thread.Sleep(1000); } sema.Release(); Console.ReadKey(); } }
代码说明:
static Semaphore sema = new Semaphore(1,1);
声明一个信号量,指示控制的资源初始和最大线程并发数为1
sema.WaitOne();
for (int i = 0; i < 3; i++)
{
Console.WriteLine($"ThreadName:{ Thread.CurrentThread.Name} i:{i}");
Thread.Sleep(1000);
}
sema.Release();
使用以上两个方法控制资源,某个线程执行sema.WaitOne()方法时,若有其他线程已经占用资源,此方法将阻塞,直到,其他线程释放,即调用sema.Release();方法
执行效果如下:
同一段时间内,只有一个线程进入共享资源中。
以下是最大并发数为2的执行效果:
static Semaphore sema = new Semaphore(2,2);
同一段时间内,有两个线程进入了贡献资源中
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通