Logo
技术 C#

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

photo
Pastore Antonio

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;
        }

 

本文为原创文章,请注意保留出处!
修复群晖Synology Drive client右键菜单缺失问题 Local, clean & environmental 作者:Pastore Antonio
1806 浏览量
1779 浏览量
configure: error: Package requirements (oniguruma) were not met Local, clean & environmental 作者:Pastore Antonio
1524 浏览量
Adobe Acrobat Pro 激活 Local, clean & environmental 作者:Pastore Antonio
1519 浏览量
追寻日出,找回自己 Local, clean & environmental 作者:Pastore Antonio
1488 浏览量