并行集合--IProducerConsumerCollection<T>

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Collections;
using System.Collections.Concurrent;
using System.Threading;
namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            //****************************【ConcurrentQueue】(先进先出)*************************************
            ConcurrentQueue cq = new ConcurrentQueue();
            for (int i = 0; i < 10; i++)
            {
                cq.Enqueue(i);//将元素添加到结尾处
            }
            int cq_result;
            cq.TryDequeue(out cq_result);//尝试移除开始处的元素,成功返回true
            cq.TryPeek(out cq_result);//访问开始处的元素,不移除
            //****************************【ConcurrentQueue】(先进后出)*************************************
            ConcurrentStack cs = new ConcurrentStack();
            for (int i = 0; i < 10; i++)
            {
                cs.Push(i);//将元素插入到顶部
            }
            int cs_result;
            cs.TryPop(out cs_result);//弹出 并返回顶部元素
            //****************************【ConcurrentQueue】*************************************
            ConcurrentBag cb = new ConcurrentBag();
            for (int i = 0; i < 10; i++)
            {
                cb.Add(i);//添加元素
            }
            int cb_result;
            cb.TryTake(out cb_result);//移除并返回元素
            //****************************【ConcurrentQueue】*************************************
            ConcurrentDictionary cd = new ConcurrentDictionary();
            cd.TryAdd("a", "曹操");
            cd.TryAdd("b", "关羽");//添加键值
            string cd_result;
            cd.TryGetValue("a", out cd_result);//获取该键对应的值
            Console.WriteLine(cd.TryUpdate("a", "刘备", "曹操"));//指定键的值与第三个参数比较,相同则把第二个参数赋值给该键
            string del_result;
            cd.TryRemove("a", out del_result);//删除并返回该键对应的值

            //****************************【BlockingCollection】*************************************
            BlockingCollection bc = new BlockingCollection(cb);
            bc.Add(1);//添加
            foreach (var item in bc)
            {
                //Console.WriteLine(item+","+bc.Take());//查看
            }

            //****************************【并行循环Parallel.For, Parallel.ForEach,Parallel.Invoke】*************************************
            //----------------------------------Parallel.For
            Parallel.For(0, 30, (r, s) =>
            {
                // 当某一个循环单元的数大于5,
                // 则跳出当前执行单元,等待其他执行单元结束
                // 所有执行单元结束后退出Parallel.For的执行
                if (r > 5)
                {
                    Console.WriteLine("a:" + r);
                    s.Break();//跳出当前单元
                }
                Console.WriteLine("b:" + r);
            });
            //----------------------------------Parallel.ForEach
            Parallel.ForEach(new int[] { 1, 2, 3, 4 }, (r, s) => {
                Console.WriteLine(r);
                s.Stop();//停止,并推出Parallel.ForEach
            });
            //----------------------------------Parallel.Invoke
            Parallel.Invoke(() => Console.WriteLine(123) ,()=>Console.WriteLine(321));//并行执行多个委托
            Console.ReadKey();
        }
    }
}

本文标题:并行集合--IProducerConsumerCollection<T>
文章出自:http://pwwzsj.com/article/gdceih.html