c# 写着玩的,两个Task并发,一个写队列一个读队列的异常情况

Posted 蒙蒙大川

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c# 写着玩的,两个Task并发,一个写队列一个读队列的异常情况相关的知识,希望对你有一定的参考价值。

  class Program
    {
        class TestEnqueue
        {
        static    Queue<string> str = new Queue<string>();
        public static   void AddEnqueue()
        {
            for (int i = 0; i < 10; i++)
            {
                string s=  i.ToString();
                    Console.WriteLine("Task1 now runing");
                str.Enqueue(s);
             }
         }
        public static void DelEnqueue()
        {
            for (int i = 0; i < 10; i++)
            {
                    //  string s = i.ToString();
                   
                  string s=  str.Dequeue();
                    Console.WriteLine("Task2 now runing::::"+ s);
                }
        }
        }
        static void Main(string[] args)
        {
            Task t1 = new Task(TestEnqueue.AddEnqueue);
            t1.Start();
            Task t2 = new Task(TestEnqueue.DelEnqueue);
            t2.Start();
            Console.ReadKey();
        }
    }
}

t2在队列为空的时候报错。

有报错时候是这样

 

好像还是没法测出两个task同时一个在写,然后一个在读。几乎同时运行的效果。

另外程序报错之后出错地str 实际是10个数的,为何有数还报错,可能是报错延缓吧,t2报错时,t1还在往里写数据,等错显示出来之后,t1运行完了。不知能否这么理解

 

加一行代码

Task t2 = new Task(TestEnqueue.DelEnqueue);
t1.Start();
t2.Wait();
t2.Start();

 启动 Task() 时效

Stopwatch sw = new Stopwatch();
sw.Start();
Task t = new Task(MakeResult);
t.Start();
sw.Stop();
Debug.WriteLine(" 触发时间ms:"+sw.Elapsed.TotalMilliseconds); ;

第一次启动20毫秒。第二次开始变低

以上是关于c# 写着玩的,两个Task并发,一个写队列一个读队列的异常情况的主要内容,如果未能解决你的问题,请参考以下文章

四叉树写着玩

如何用电脑记事本写程序?(零基础学习,之前基本不用电脑,只用手机。)

获取iOS内存使用情况

php l练习(写着玩)

JVM上小众语言的苦苦挣扎——Clojure Tutorial 从入门到放弃

java会话管理之Cookie基础(写着玩)