C# 队列(Queue)解决简单并发

本文介绍了一个简单的日志管理系统实现方案,该系统使用线程安全的队列存储日志消息,并通过线程池来异步处理日志记录。当有新的日志条目加入时,系统会检查当前是否有线程正在运行打印日志的任务,如果没有,则启动一个线程来处理队列中的日志。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

日志例子:

        private static Queue<string> m_Message = new Queue<string>();
        private static bool m_IsRunning;
     public  void LogResult2(string sWord)
        {
            lock (m_Message)
            {
                //将日志加入到队列中
                m_Message.Enqueue(sWord);
            }
            //判断打印日志的方法是否在跑
            if (!m_IsRunning)
            {
                m_IsRunning = true;
                System.Threading.ThreadPool.QueueUserWorkItem(delegate
                {
                    Print();
                });
            }
        }
        //打印日志
        private static void Print()
        {
            while (true)
            {
                var messge = string.Empty;
                lock (m_Message)
                {
                    //队列里的条数为0时,跳出
                    if (m_Message.Count == 0)
                    {
                        m_IsRunning = false;
                        return;
                    }
                    //取出队列里的值
                    messge = m_Message.Dequeue();
                    string filePath = AppDomain.CurrentDomain.BaseDirectory + DateTime.Now.ToString("yyyyMMdd") + ".txt";
                    FileStream fs = new FileStream(filePath, FileMode.Append);
                    StreamWriter sw = new StreamWriter(fs, System.Text.Encoding.Default);
                    sw.Write(messge);
                    sw.Close();
                    fs.Close();
                }
            }
        }

 

转载于:https://www.cnblogs.com/cang12138/p/6211140.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值