C# DataFlow入门(二、属性配置)

   #region 一、DataflowBlockOptions 
        /***
         *  1. BoundedCapacity 最大处理数目 设置容量
         *  2. CancellationToken 用于提前取消流处理
         *  3. MaxMessagesPerTask 控制公平性 多个源,每个源处理相同的任务
         *  4. NameFormat 定义Block的名称
         *  5. TaskScheduler 任务调用逻辑
         */
        // 1.BoundedCapacity
        private BufferBlock<int> b1 = new BufferBlock<int>(new DataflowBlockOptions() {
            BoundedCapacity = 1
        });
        public void TestBoundedCapacity() {
            for (int i = 0; i < 10; i++) {
                b1.Post(i);
            }
            while (!b1.Completion.IsCompleted) {
                Console.WriteLine(b1.Receive());
            }
        }

        // 2. CancellationToken
        private static CancellationTokenSource cts = new CancellationTokenSource();

        private BufferBlock<int> b2 = new BufferBlock<int>(new DataflowBlockOptions()
        {
            CancellationToken = cts.Token
        });
        public void TestCancellationToken()
        {
            Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 10; i++)
                {
                    Thread.Sleep(1000);
                    b2.Post(i);
                    if (i == 5)
                    {
                        cts.Cancel();
                    }
                }
            });
            Task.Factory.StartNew(() =>
            {
                while (!b2.Completion.IsCompleted)
                {
                    Thread.Sleep(500);
                    if (cts.IsCancellationRequested)
                    {
                        Console.WriteLine("已取消");
                        break;
                    }
                    Console.WriteLine(b2.Receive());
                }
            });

        }

        // 3. MaxMessagesPerTask
        BufferBlock<int> b3 = new BufferBlock<int>();
        BufferBlock<int> b4 = new BufferBlock<int>();
        BufferBlock<int> b5 = new BufferBlock<int>();
        BufferBlock<int> b6 = new BufferBlock<int>(new DataflowBlockOptions() { MaxMessagesPerTask = 1 });

        public void TestMaxMessagesPerTask()
        {
            b3.LinkTo(b6);
            b4.LinkTo(b6);
            b5.LinkTo(b6);
            Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 5; i++) {
                    Thread.Sleep(50);
                    b3.Post(i);
                }
            });

            Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 5; i++)
                {
                    Thread.Sleep(50);
                    b4.Post(i + 10);
                }
            });

            Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 5; i++)
                {
                    Thread.Sleep(50);
                    b5.Post(i + 100);
                }
            });

            Task.Factory.StartNew(() =>
            {
                while (!b6.Completion.IsCompleted)
                {
                    Console.WriteLine(b6.Receive());
                }
            });


        }

        // 4. NameFormat
        static string name = "b7";
        BufferBlock<int> b7 = new BufferBlock<int>(new DataflowBlockOptions() { NameFormat = name });

        public void TestNameFormat() {
            for (int i = 0; i < 10; i++) {
                b7.Post(i);
            }
            while (!b7.Completion.IsCompleted) {

                Console.WriteLine("name:" + b7.ToString() + " id:" + b7.Completion.Id + " value:" + b7.Receive());
            }
        }

        // 5. TaskScheduler
        /**
         * ThreadPoolTaskScheduler 默认的
         * SynchronizationContextTaskScheduler UI建议
         * ConcurrentExclusiveSchedulerPair 同步/独占
         */
        public void TestTaskScheduler()
        {
            ConcurrentExclusiveSchedulerPair pair = new ConcurrentExclusiveSchedulerPair();
            BufferBlock<int> b8 = new BufferBlock<int>(new DataflowBlockOptions() { TaskScheduler = pair.ExclusiveScheduler });
            BufferBlock<int> b9 = new BufferBlock<int>(new DataflowBlockOptions() { TaskScheduler = pair.ExclusiveScheduler });
            BufferBlock<int> b10 = new BufferBlock<int>(new DataflowBlockOptions() { TaskScheduler = pair.ExclusiveScheduler });

            BufferBlock<int> b11 = new BufferBlock<int>(new DataflowBlockOptions() { TaskScheduler = pair.ExclusiveScheduler });
            b8.LinkTo(b11);
            b9.LinkTo(b11);
            b10.LinkTo(b11);
            for (int i = 0; i < 3; i++)
            {
                b8.Post(i);
            }
            for (int i = 0; i < 3; i++)
            {
                b9.Post(i + 10);
            }
            for (int i = 0; i < 3; i++)
            {
                b10.Post(i + 100);
            }
            while (!b11.Completion.IsCompleted)
            {

                Console.WriteLine(" value:" + b11.Receive());
            }
        }

        #endregion
        #region 二、ExecutionDataflowBlockOptions 
        /****
         * DataflowBlockOptions的派生类
         *  1. BoundedCapacity 最大处理数目 设置容量
         *  2. CancellationToken 用于提前取消流处理
         *  3. MaxMessagesPerTask 控制公平性 多个源,每个源处理相同的任务(理论上是)
         *  4. NameFormat 定义Block的名称
         *  5. TaskScheduler 任务调用逻辑
         *  
         *  以上均与DataflowBlockOptions相同,不再赘述
         *  
         *  6. EnsureOrdered 默认值为false,其是用来将输出结果进行排序的
         *  7. MaxDegreeOfParallelism 最大并行任务数
         *  8. SingleProducerConstrained 还不是很清楚
         */

        TransformBlock<int, string> TransformBlock = new TransformBlock<int, string>((i) => {
            Thread.Sleep(1000);
            return "value:" + i + " ThreadId:" + Thread.CurrentThread.ManagedThreadId + " Execute Time:" + DateTime.Now;
        }, new ExecutionDataflowBlockOptions() { MaxDegreeOfParallelism = 5, EnsureOrdered = true });
        ActionBlock<string> action = new ActionBlock<string>((i) => {
            Console.WriteLine(i);
        });

        public void TestEnsureOrderedAndMaxDegreeOfParallelism() {
            TransformBlock.LinkTo(action);
            for (int i = 0; i < 50; i++) {
                TransformBlock.Post(i);
            }
        }

        ActionBlock<int> ab10 = new ActionBlock<int>((i) =>
        {
            Console.WriteLine(i);
        },new ExecutionDataflowBlockOptions() { SingleProducerConstrained = true});
        public void TestSingleProducerConstrained() {
            Stopwatch stopwatch = new Stopwatch();
            stopwatch.Start();
            Task.Factory.StartNew(() =>
            {
                for (int i = 0; i < 5000; i++)
                {
                    ab10.Post(i);
                }
                Console.WriteLine("1 Finished post "+ stopwatch.ElapsedMilliseconds);
                ab10.Complete();
            });

            while (!ab10.Completion.IsCompleted) { 

            }
            Console.WriteLine("1 IsCompleted " + stopwatch.ElapsedMilliseconds);
        }
        #endregion
        #region 三、GroupingDataflowBlockOptions 
        /****
         * DataflowBlockOptions的派生类
         *  1. BoundedCapacity 最大处理数目 设置容量
         *  2. CancellationToken 用于提前取消流处理
         *  3. MaxMessagesPerTask 控制公平性 多个源,每个源处理相同的任务
         *  4. NameFormat 定义Block的名称
         *  5. TaskScheduler 任务调用逻辑
         *  6. EnsureOrdered 默认值为false,其是用来将输出结果进行排序的
         *  以上均与DataflowBlockOptions相同,不再赘述
         *  
         *  
         *  7. Greedy 贪婪,限制msg使用
         *  8. MaxNumberOfGroups 最大组数。限制输出的组数
         */

        BatchBlock<int> bb13 = new BatchBlock<int>(3,new GroupingDataflowBlockOptions() { Greedy=false});
        BatchBlock<int> bb14 = new BatchBlock<int>(3, new GroupingDataflowBlockOptions() { Greedy = true,MaxNumberOfGroups = 2 });

        ActionBlock<int[]> ab13 = new ActionBlock<int[]>((i) =>
        {
            string s = string.Empty;

            foreach (int m in i)
            {
                s += m + " ";
            }
            Console.WriteLine(s);
        });

        public void TestGreedy()
        {
            bb13.LinkTo(ab13);
            bb14.LinkTo(ab13);
            for (int i = 0; i < 10; i++)
            {
                bb13.Post(i);
                bb14.Post(i+100);
            }
            bb13.Complete();

            Console.WriteLine("Finished post");
        }
        #endregion

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值