c# ConcurrentQueue 性能测试

using System;
using System.Collections.Concurrent;
using System.Diagnostics;
using System.Threading.Tasks;

namespace ThreadCQueue
{
    class Program
    {
        const int count = 10000000;
        const int threadCount = 100;

        static void Main(string[] args)
        {
            Task t = RunProgram();
            t.Wait();
            Console.WriteLine("ok");
            Console.ReadKey();
        }

        static async Task RunProgram()
        {
            var taskQueue = new ConcurrentQueue<CustomTask>();
            //生产

            var taskSource = Task.Run(() => TaskProducer(taskQueue));
            await taskSource;
            //消费者
            Stopwatch sw = new Stopwatch();
            sw.Start();
            var processors = new Task[threadCount];
            for (var i = 1; i <= threadCount; i++)
            {
                string processordId = i.ToString();
                processors[i - 1] = Task.Run(() => TaskProcessor(taskQueue, $"Processor {processordId}"));
            }
            await Task.WhenAll(processors);
            //停止计时
            sw.Stop();
            Console.WriteLine("用时2:" + sw.ElapsedMilliseconds + "");
        }



        static async Task TaskProducer(ConcurrentQueue<CustomTask> queue)
        {
            Stopwatch sw = new Stopwatch();
            sw.Start();
            for (var i = 1; i <= count; i++)
            {
                //await Task.Delay(50);
                var workItem = new CustomTask { Id = i };
                queue.Enqueue(workItem);
            }
            //停止计时
            sw.Stop();
            Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "");

        }
        static async Task TaskProcessor(ConcurrentQueue<CustomTask> queue, string name)
        {
            CustomTask workItem;
            //await GetRandomDelay();
            while (queue.TryDequeue(out workItem))
            {
                //Console.WriteLine($"消费 {workItem.Id}===>{name}");
                //await GetRandomDelay();
            }
        }

        static Task GetRandomDelay()
        {
            int delay = new Random(DateTime.Now.Millisecond).Next(1, 500);
            return Task.Delay(delay);
        }
    }
    class CustomTask
    {
        public int Id { get; set; }
    }
}

1000万条,入队出队大概1秒

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值