C#使用队列(Queue)解决简单的并发问题

2019-12-26 13:02:57王振洲

易采站长站为您分析使用队列(Queue)解决简单的并发问题,讲解的很细致,喜欢的朋友们可以了解一下

本文通过实例,更具体的讲解了队列,队列(Queue)代表了一个先进先出的对象集合。当您需要对各项进行先进先出的访问时,则使用队列。当您在列表中添加一项,称为入队,当您从列表中移除一项时,称为出队。

有一个场景:一个抢购的项目,假设有5件商品,谁先抢到谁可以买,但是如果此时此刻(这里的此时此刻假设是相同的时间),有100人去抢这个商品,如果使用平时的方法会出现什么情况呢?你懂的,这里所说是就是有关并发的问题。

平时我们去超市购物去结账的时候就是排队,这里我们先让抢购人排好队,按时间,谁先点击的抢购按钮谁就排在前面,这样就形成了一个队列,然后我们再对这个队列处理,这样就不会出现并发的问题了。(至少可以处理这样简单的并发,这里不讨论太复杂的并发)

案例:

要求:有一个发布文章的接口,每发布一篇文章,调用一下接口。(这里不用批量发布,为了讲解这个)

建立一个这样的处理程序类,BusinessInfoHelper.cs

 

 
  1. namespace MyNameSpace    
  2. {   //队列临时类  
  3. public class QueueInfo   {  
  4. public string medias { get; set; }   public string proids { get; set; }  
  5. public string host { get; set; }   public string userid { get; set; }  
  6. public string feedid { get; set; }   }  
  7.   public class BusinessInfoHelper  
  8. {   #region 解决发布时含有优质媒体时,前台页面卡住的现象  
  9. //原理:利用生产者消费者模式进行入列出列操作    
  10. public readonly static BusinessInfoHelper Instance = new BusinessInfoHelper();   private BusinessInfoHelper()  
  11. { }    
  12. private Queue<QueueInfo> ListQueue = new Queue<QueueInfo>();    
  13. public void AddQueue(string medias, string proids, string host, string userid, string feedid) //入列   {  
  14. QueueInfo queueinfo = new QueueInfo();