消息队列使用,异步执行,加快速度

原创 2015年11月20日 09:55:12

//定义队列  

 private readonly Queue<TrainLandingPageInfo> documentQueue = new Queue<TrainLandingPageInfo>();

        public void AddDocument(TrainLandingPageInfo model)
        {
            lock (this)
            {
                documentQueue.Enqueue(model);
//如果线程未启动,则启动线程,否则只要加入到队列中便可以了。
                if (threadWatch==null || !threadWatch.IsAlive)
                {
                    //创建线程
                    threadWatch = new Thread(AddLoadpage);                     
                    //启动线程
                    threadWatch.Start();
                }
            }

        }

//处理队列数据

 private void AddLoadpage()
        {
            while (documentQueue.Count > 0)
            {
                TrainLandingPageInfo client = GetDocument();
                try
                {
                    int pid = TrainLanPageDAL.AddFcate(client.fidname, client.SiteID, 0);
                    client.CatID = TrainLanPageDAL.AddFcate(client.catname, client.SiteID, pid);
                    if (client.CatID > 0)
                        TrainLanPageDAL.AddLoadpage(client);
                }
                catch (Exception ex)
                {
                    
                }
            }
        }

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Redis应用3-基于Redis消息队列实现的异步操作

Redis实现消息队列的模式常用的消息队列有RabbitMQ, ActiveMQ, Kafka等,这都是开源的功能强大的消息队列,适合于在企业项目应用。Redis实现的消息队列代码原理 Redis...

linux 消息队列使用示例

Linux下消息队列和socket绝对速度比拼

原文链接:http://blog.csdn.net/diaoyf/article/details/4604625 【本文已迁移到“程序员文摘” http://programmerdi...

Lua App中通过Sqlite实现消息队列(异步通信)

实践动机和目标目前具有社交功能的App中大量使用本地Sql来存储用户记录,同时为了优化用户体验,这些App都愿意提供用户在无网(或弱网)环境下操作的需求。

采用线程池和消息队列的“伪异步”I/O模型

参考:《Netty权威指南》 由于 一请求一线程 的I/O模型,在高并发时创建大量的线程,严重降低系统性能,并且容易造成线程堆栈溢出等问题。 采用线程池和消息队列的“伪异步”模型,是一种改...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)