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并发,一个写队列一个读队列的异常情况的主要内容,如果未能解决你的问题,请参考以下文章
如何用电脑记事本写程序?(零基础学习,之前基本不用电脑,只用手机。)