zoukankan      html  css  js  c++  java
  • .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;
            }
        }
  • 相关阅读:
    Python进阶2.3 with的使用
    thinkswoole 跨域
    调用windows服务来监视文件夹状态
    IIS 文件名、目录名或卷标语法不正确解决方法一例
    jqgrid 动态列生成
    Oracle 术语解释 只有一部分
    招聘.NET高级软件工程师
    Zabbix监控集群操作用户“登录失败次数“和“失败日志记录“
    Gin框架组合(Zap、lumberjack、ini)使用手册
    逛书城有感
  • 原文地址:https://www.cnblogs.com/zhangjd/p/13409224.html
Copyright © 2011-2022 走看看