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

热门文章

修复群晖Synology Drive client右键菜单缺失问题 本教程主要解决windows10右键菜单中没有SynologyDrive菜单的问题,整体思路是找到...修复群晖SynologyDriveclient右键菜单缺失问题 作者:Pastore Antonio
1812 浏览量
docker如何查看一个镜像内部的目录结构及其内部都有哪些文件 前言:有时候我们会在docker上下载一个镜像,或者是上传一个镜像到docker上,甚至有时候就是在...docker如何查看一个镜像内部的目录结构及其内部都有哪些文件 作者:Pastore Antonio
1791 浏览量
configure: error: Package requirements (oniguruma) were not met configure:error:Packagerequirements(oniguruma)...configure:error:Packagerequirements(oniguruma)werenotmet 作者:Pastore Antonio
1530 浏览量
Adobe Acrobat Pro 激活 这里记录了一些AdobeAcrobat的激活教程和组件。浏览量:1,683 作者:Pastore Antonio
1528 浏览量
追寻日出,找回自己 为什么我要去追寻日出?其实我是一个很懒的人,每次都起不来,直到有一次我在租房中睡到了大天亮,阳光照...追寻日出,找回自己 作者:Pastore Antonio
1506 浏览量