声明:
var semaphore=new Semaphore(10, 10, "QSemaphoreTest");
//var semaphore=new Semaphore(10, 10);//Linux下不要指定name,因为linux下不支持自定义名称,会报错
第一个数字10代表初始化可争抢的空闲资源
第二个数字10代表最大可争抢的资源(前面的不能大于后面数字)
第三个代表,名称,不必须
– 说明:初始化生成10个资源,最多不能申请超过10个资源;
等价于Lock-推荐
var semaphore=new Semaphore(1, 1, "QSemaphoreTest");
本地数据队列转换为线程队列,控制处理速度
注意:会造成线程积压,多余的线程不执行,但会等待(占用内存)
private static Semaphore semaphore = new Semaphore(5, 5, "QSemaphoreTest");
while(LocalQueue) //只产生异步线程,所以会产生非常多线程
{
Thread thread = new Thread(new ParameterizedThreadStart(Work));
thread.Start();
}
void Work(object obj)
{
if (LocalQueue.TryDequeue(out object mq))
{
semaphore.WaitOne();//在线程里控制处理流量
CommandCenterMessageDefaultHandle_2(mq);
semaphore.Release();
}
}
控制总线程的生产-推荐
private static Semaphore semaphore = new Semaphore(5, 5, "QSemaphoreTest");
static void Main(string[] args)
{
int i= 1;
while (true)
{
semaphore.WaitOne();//在开始执行时申请资源
ThreadPool.QueueUserWorkItem(item => Dequeue());
Console.WriteLine(i++);
}
}
public static void Dequeue()
{
var rdm = new Random().Next(1, 10);
Thread.Sleep(rdm * 1000);
Console.WriteLine("消费Local队列");
semaphore.Release();//在具体执行方法里释放资源
}