C# 使用Parallel并行对比lock锁和ConcurrentQueue并发性能

using System;
using System.Collections;
using System.Collections.Concurrent;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;

namespace ConsoleApp2
{
    class Program
    {
        private static object o = new object();

        private static Queue<Product> _ProductsNormal { get; set; }
        private static Queue<Product> _Products { get; set; }
        private static ConcurrentQueue<Product> _ConcurrenProducts { get; set; }

        /*  -------------------------------------------
         *  对比lock锁和ConcurrentQueue并发性能
         *  -------------------------------------------
            在.NET Framework4.0以后的版本中提供了命名空间:System.Collections.Concurrent 来解决线程安全和lock锁性能问题,通过这个命名空间,能访问以下为并发做好了准备的集合。
            1.BlockingCollection 与经典的阻塞队列数据结构类似,能够适用于多个任务添加和删除数据,提供阻塞和限界能力。
            2.ConcurrentBag 提供对象的线程安全的无序集合
            3.ConcurrentDictionary  提供可有多个线程同时访问的键值对的线程安全集合
            4.ConcurrentQueue   提供线程安全的先进先出集合
            5.ConcurrentStack   提供线程安全的后进先出集合
            这些集合通过使用比较并交换和内存屏障等技术,避免使用典型的互斥重量级的锁,从而保证线程安全和性能。
         */
        static void Main(string[] args)
        {
            #region 不启用并行计算使用锁lock
            //休眠重置校准结果
            Thread.Sleep(1000);
            _ProductsNormal = new Queue<Product>();

            Stopwatch swTaskn = new Stopwatch();//用于统计时间消耗的
            swTaskn.Start();
            Task tn1 = Task.Factory.StartNew(() => { AddProductsNormal(); });
            Task tn2 = Task.Fact
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

smartsmile2012

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值