• .NetCore 线程安全的ConcurrentQueue<T>队列


    摘要:最近办了一件蠢事,我在一个高并发的订阅事件里对数据库执行I/O操作 ,坑了自己一把,虽然定时清除了数据,但是跑了一段时间之后还是出问题了,后面就加入了队列去存储一段时间的数据,解决了这个问题,操作内存和磁盘不是一个级别的.特别是高并发的情况下,最好别对磁盘进行I/O操作,用不好只能坑了自己.

    这里简单粘一下队列的使用方法,因为用的是多线程,就选择了ConcurrentQueue,还有一些别的Queue方法,有兴趣可以去搜一下.

    ConcurrentQueue<T>队列是一个高效的线程安全的队列,是.Net Framework 4.0,System.Collections.Concurrent命名空间下的一个数据结构

     ConcurrentQueue是一个先进先出的队列,常用的有以下几个方法:

    • Enqueue(T item)  将对象添加到队列的结尾处
    • TryDequeue(out T result)  尝试移除并返回并发队列开头处的对象
    • TryPeek(out T result)  尝试返回开头处的对象但不将其移除

    以下是我封装的常用类

        public class RingStringBuilder
        {
            private static ConcurrentQueue<RealTimeInfo> concurrentQueue = new ConcurrentQueue<RealTimeInfo>();
            private static int _maxCapacity;//队列最大值
    
            public RingStringBuilder(int maxCapacity)
            {
                _maxCapacity = maxCapacity;
            }
            /// <summary>
            /// 根据队列设置的最大值判断
            /// 超过最大值,移除队列第一条,队列末尾添加一条
            /// 没超过最大值,一直在队列尾部添加
            /// </summary>
            /// <param name="info"></param>
            public static void Append(RealTimeInfo info)
            {
                concurrentQueue.Enqueue(info);
                if (concurrentQueue.Count > _maxCapacity)
                {
                    concurrentQueue.TryDequeue(out info);
                }
            }
            /// <summary>
            /// 查询列表
            /// </summary>
            /// <returns></returns>
            public static List<RealTimeInfo> Query()
            {
                return concurrentQueue.ToList();
            }
    
            /// <summary>
            /// 获取最后一条数据
            /// </summary>
            /// <returns></returns>
            public static RealTimeInfo GetLastOrDefault()
            {
                return concurrentQueue.LastOrDefault();
            }
    
            /// <summary>
            /// 获取第一条数据
            /// </summary>
            /// <param name="info"></param>
            /// <returns></returns>
            public static RealTimeInfo GetFirstOrDefault(out RealTimeInfo info)
            {
                concurrentQueue.TryPeek(out info);
                return info;
            }
        }
  • 相关阅读:
    操作系统——第四章 文件管理
    操作系统——第三章 内存管理
    操作系统——第二章 进程管理
    last-child到底怎么用
    Https个人总结
    白话https
    RSA算法
    算法导论笔记:11散列表(哈希表)
    算法导论笔记:10基本数据结构(番外)
    算法导论笔记:09中位数和顺序统计量
  • 原文地址:https://www.cnblogs.com/zhangjd/p/13409224.html
Copyright © 2020-2023  润新知