Logo

C# WaitAll 等待所有线程执行完毕

photo

2022年05月13日

 方法一

        private void button1_Click(object sender, EventArgs e)
        {
            DateTime start = DateTime.Now;
            List<Task> taskList = new List<Task>();
            taskList.Add(Task.Run(() =>
            {

                Thread.Sleep(3000);
                Console.WriteLine("三秒输出");
            }));
            taskList.Add(Task.Run(() =>
            {

                Thread.Sleep(7000);
                Console.WriteLine("七秒输出");
            }));
            taskList.Add(Task.Run(() =>
            {

                Thread.Sleep(5000);
                Console.WriteLine("五秒输出");
            }));
            //等待结束
            Task.WaitAll(taskList.ToArray());
            DateTime end = DateTime.Now;
            int num = GetTimeSpanSeconds(start, end);
            Console.WriteLine($"三个线程已执行完毕,用时:{num}s");

        }
        /// <summary>
        /// 两个时间间隔秒数
        /// </summary>
        /// <param name="startTime"></param>
        /// <param name="endTime"></param>
        /// <returns></returns>
        public static int GetTimeSpanSeconds(DateTime startTime, DateTime endTime)
        {
            TimeSpan ts = endTime.Subtract(startTime);
            int sec = (int)ts.TotalSeconds;
            return sec;
        }

 方法二

        private void button1_Click(object sender, EventArgs e)
        {
            DateTime start = DateTime.Now;
            AutoResetEvent[] watchers = new AutoResetEvent[3];
            watchers[0] = new AutoResetEvent(false);
            //启动10个线程输出10个数字
            new Thread(() =>
            {
                Thread.Sleep(3000);
                Console.WriteLine("三秒输出");
                watchers[0].Set();     //线程执行完的时候通知
            }).Start();


            watchers[1] = new AutoResetEvent(false);
            //启动10个线程输出10个数字
            new Thread(() =>
            {
                Thread.Sleep(7000);
                Console.WriteLine("七秒输出");
                watchers[1].Set();     //线程执行完的时候通知
            }).Start();


            watchers[2] = new AutoResetEvent(false);
            //启动10个线程输出10个数字
            new Thread(() =>
            {
                Thread.Sleep(5000);
                Console.WriteLine("五秒输出");
                watchers[2].Set();     //线程执行完的时候通知
            }).Start();

            WaitHandle.WaitAll(watchers);  //确保所有线程都执行完毕
            DateTime end = DateTime.Now;
            int num = GetTimeSpanSeconds(start, end);
            Console.WriteLine($"三个线程已执行完毕,用时:{num}s");            
        }
        /// <summary>
        /// 两个时间间隔秒数
        /// </summary>
        /// <param name="startTime"></param>
        /// <param name="endTime"></param>
        /// <returns></returns>
        public static int GetTimeSpanSeconds(DateTime startTime, DateTime endTime)
        {
            TimeSpan ts = endTime.Subtract(startTime);
            int sec = (int)ts.TotalSeconds;
            return sec;
        }

 

橙子主题打折出售

其实我不卖,主要是这里是放广告的,所以就放了一个
毕竟主题都没做完,卖了也是坑.

购买它
所有附件
该文章没有附件.
本文为原创文章,请注意保留出处!

有一群友问到关于SharePoint列表的导入与导出的问题,而最近也要做相关操作且好久没写博客了...SharePoint列表的导出导入

热门文章

Navicat Premium 12.0.22 安装与破解 一、安装  NavicatPremium12.0.22的下载链接:https://pan.ba...NavicatPremium12.0.22安装与破解 作者:Pastore Antonio
1515 浏览量
C# JArray与JObject 的使用 STEP1、usingNewtonsoft.Json.Linq;STEP2、如何获取json里的...C#JArray与JObject的使用 作者:Pastore Antonio
1465 浏览量
解决mysql的配置ONLY_FULL_GROUP_BY引起的错误 由于自己的本地网站环境使用了mysql8.0的版本,在测试一个groupby的sql查...解决mysql的配置ONLY_FULL_GROUP_BY引起的错误 作者:Pastore Antonio
1448 浏览量
Windows server 2016 英文服务器安装中文语言包教程 1、下载windowsserver2016语言包下载地址:https://pan.baidu....Windowsserver2016英文服务器安装中文语言包教程 作者:Pastore Antonio
1406 浏览量
assembly(全局程序集缓存)中dll的导入和导出 本文主要讲一下关于assembly中的dll是怎么导入和导出的。浏览量:1,468 作者:Pastore Antonio
1403 浏览量