最近接手同事C#代码,(话说我一个C++程序员干嘛做这种事情,可能我是韭菜吧),为了能够承接,特地去拜读了《C#图解教程》,入门还是不错的。

写代码嘛,异步编程肯定少不了,下面就是利用C# BlockingCollection功能模块编写的 生产者/消费者 demo(韭菜要自觉生产,提供给多人消费)。

using System;
using System.Threading;
using System.Threading.Tasks;
using System.Collections.Concurrent;
namespace ConsoleApp2
    class Collection
        public static BlockingCollection<int> bc = new BlockingCollection<int>();
    class Producer
        public static async Task Producer_fun()
            await Task.Run(() => {
                for (int i = 0; i < 100; i++)
                    Thread.Sleep(50);
                    Collection.bc.Add(i);
                    Console.WriteLine($"韭菜生产 {i}");
                Collection.bc.CompleteAdding();
    class Consumer
        public static int n = 0;
        public static async Task Consumer_fun(string str)
            await Task.Run(() =>
                while(true){
                    Thread.Sleep(200);
                    if (Collection.bc.TryTake(out n))
                        Console.WriteLine($"{str}掠夺 {n}");
                        if (Collection.bc.IsCompleted)
                            break;
    class Program
        static void Main(string[] args)
            Task t1 = Producer.Producer_fun();
            Task t2 = Consumer.Consumer_fun("JD");
            Task t3 = Consumer.Consumer_fun("ali");
            Task t4 = Consumer.Consumer_fun("QQ");
            Task t5 = Consumer.Consumer_fun("apple");
            Task.WaitAll(t1, t2, t3,t4,t5);

相对于C++来说,C#的BlockingCollection(生产/消费)使用真的非常方便,还线程安全。。。。