有一个秒杀场景,产品库存只有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将元素复制到新数组的方法。
功能和方法由于时间关系就不在这里一一提及了,感兴趣的自己去研究吧。最后,只是告诉你有这么一个类,怎么应用和如何用就根据自己的需求去了解吧。