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列表的导出导入

热门文章

Sql Server 部署SSIS包完成远程数据传输 本篇介绍如何使用SSIS和作业完成自动更新目标数据任务。**温馨提示:如需转载本文,请注明...SqlServer部署SSIS包完成远程数据传输 作者:Pastore Antonio
1618 浏览量
EWS(Exchange Service)基本使用(获取个人会议,会议室会议内容,会议室列表,发送会议,修改会议,删除会议) 最近公司要求和exchange服务对接,所以稍微研究了一下官方文档,做出以下总结,欢迎大家补充。先...EWS(ExchangeService)基本使用(获取个人会议,会议室会议内容,会议室列表,发送会议,修改会议,删除会议) 作者:Pastore Antonio
1611 浏览量
SharePoint2010升级到SharePoint2013操作手册 SharePoint2010升级到SharePoint2013操作手册目录第一章...SharePoint2010升级到SharePoint2013操作手册 作者:Pastore Antonio
1597 浏览量
SQL Server AG集群启动不起来的临时自救大招 背景前晚一朋友遇到AG集群发生来回切换不稳定的情况,情急之下,朋友在命令行使用命令重启WSFC集群...SQLServerAG集群启动不起来的临时自救大招 作者:Pastore Antonio
1597 浏览量
C# DataTable 某一列求和 列为数字类型doubletotal=Convert.ToDouble(datatable.Com...C#DataTable某一列求和 作者:Pastore Antonio
1585 浏览量