通过Queue 类解决C#数据并发问题

2023-03-08 16:39:24 浏览数 (1)

有一个秒杀场景,产品库存只有5个,谁先抢到谁可以买,于是如何去界定这5个产品的归属;当然你可以说以时间,可以但容易出错,因为这个时间就需要到豪秒级的判断了。

那有什么其他办法呢?最近用到了一个Queue 类,这个类的好处是:对象的先进先出集合,就是说进入早的就出的早,晚的就晚出,这个好理解吧。这样就解决多线程下的出入问题。

我们还是举个例子吧,上代码。

代码语言:javascript复制
Queue car= new Queue();// 
car.Enqueue("A乘客");
car.Enqueue("B乘客");   
car.Enqueue("C乘客");   
//乘客列表
foreach (Object obj in car)
{
    Console.Write("    {0}", obj);
}
Console.WriteLine($"乘客总数量:" car.Count "个");

//乘客下车
Console.WriteLine("rn(Dequeue)t{0}", car.Dequeue());

上面的代码就一个简单的先进先出例子,乘客排序上车,然后由先进的进行下车。

当然上面只是简单地描述了一下Queue 的用途,它除了刚提到的Dequeue() 方法还有一个Enqueue()进行元素添加都结尾的方法,还有2个比较好用的方法: Queue.CopyTo(Array, Int32) 这个是将元素复制到指定的一维数组中及Queue.ToArray将元素复制到新数组的方法。

功能和方法由于时间关系就不在这里一一提及了,感兴趣的自己去研究吧。最后,只是告诉你有这么一个类,怎么应用和如何用就根据自己的需求去了解吧。

0 人点赞