zoukankan      html  css  js  c++  java
  • ConcurrentQueue对列

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

    • IsEmpty  获取一个值,判断是否为空
    • Count  获取包含的元素数
    • Enqueue(T item)  将对象添加到队列的结尾处
    • TryDequeue(out T result)  尝试移除并返回并发队列开头处的对象
    • TryPeek(out T result)  尝试返回开头处的对象但不将其移除
    • ElementAt(int index)  返回序列中的指定索引处的元素
    using System;
    using System.Collections.Concurrent;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
     
    namespace TestConcurrentQueue
    {
        class Program
        {
            static void Main(string[] args)
            {
                //ConcurrentQueue 表示线程安全的先进先出 (FIFO) 集合
                ConcurrentQueue<Employee> currendQueue = new ConcurrentQueue<Employee>();
                Employee empOne = , "市场部");
                Employee empTwo = , "技术部");
                Employee empThree = , "市场部");
                //Enqueue(T item) 将对象添加到结尾处
                currendQueue.Enqueue(empOne);
                currendQueue.Enqueue(empTwo);
                currendQueue.Enqueue(empThree);
     
                //获取包含的元素数
                )
                {
                    //TryDequeue(out T result) 尝试移除并返回并发队列开头处的对象
                    currendQueue.TryDequeue(out Employee employee);
                    Console.WriteLine(employee);
     
                    )
                    {
                        ; i < currendQueue.Count; i++)
                        {
                            Employee emp = currendQueue.ElementAt(i);
                            Console.WriteLine(emp);
                        }
                    }
                }
            }
        }
     
        /// <summary>
        /// 雇员类
        /// </summary>
        class Employee
        {
            /// <summary>
            /// 雇员姓名
            /// </summary>
            public string EmpName { get; set; }
            /// <summary>
            /// 雇员性别
            /// </summary>
            public string EmpSex { get; set; }
            /// <summary>
            /// 雇员年龄
            /// </summary>
            public int EmpAge { get; set; }
            /// <summary>
            /// 雇员部门
            /// </summary>
            public string DeptName { get; set; }
            /// <summary>
            /// 构造函数
            /// </summary>
            /// <param name="empName"></param>
            /// <param name="empSex"></param>
            /// <param name="empAge"></param>
            /// <param name="deptName"></param>
            public Employee(string empName, string empSex, int empAge, string deptName)
            {
                EmpName = empName;
                EmpSex = empSex;
                EmpAge = empAge;
                DeptName = deptName;
            }
     
            public override string ToString()
            {
                return "Employee[EmpName=" + EmpName + ",EmpSex=" + EmpSex + ",EmpAge=" + EmpAge + ",DeptName=" + DeptName + "]";
            }
        }
    }
    /// <summary>
    /// 获取对列数量
    /// </summary>
    /// <returns></returns>
    Queue.Count
     
     
    /// <summary>
    /// 确定序列是否包含任何元素[用于判断对列是否有要处理的数据]这个方法的性能比Count()方法快
    /// </summary>
    /// <returns></returns>
    Queue.Any()

    以上就是对列的基本使用方法。

    对列的使用场景有很多。所有要异步处理的都可以使用对列的方式。如接口日志异步处理,邮件、短信异步发送等。对列一般配合单例设计模式和线程一起使用更佳。

    文章参考:https://www.cnblogs.com/stevenchen2016/p/5397270.html   https://www.bbsmax.com/A/A2dmg67gJe/   https://blog.csdn.net/liunianqingshi/article/details/79025818

      

  • 相关阅读:
    bzoj4518[Sdoi2016]征途 斜率优化dp
    bzoj3675[Apio2014]序列分割 斜率优化dp
    bzoj3437小P的牧场 斜率优化dp
    bzoj3156防御准备 斜率优化dp
    bzoj1911[Apio2010]特别行动队 斜率优化dp
    bzoj5100 [POI2018]Plan metra 构造
    bzoj1597[Usaco2008 Mar]土地购买 斜率优化dp
    刷题总结——Middle number(ssoj 优先队列)
    刷题总结——doing homework again(hdu1789)
    NOIP2017赛前模拟(3):总结
  • 原文地址:https://www.cnblogs.com/whitebai/p/12703487.html
Copyright © 2011-2022 走看看