C#多线程并发【深入浅出实战】

创建一个线程

Task的创建和执行方式有如下三种: 可以带参数

 public void testTask(string[] args)
        {
            //1.new方式实例化一个Task,需要通过Start方法启动
            Task task = new Task(() =>
            {
                Thread.Sleep(100);
                Console.WriteLine($"hello, task1的线程ID为{Thread.CurrentThread.ManagedThreadId}");
            });
            task.Start();

            //2.Task.Factory.StartNew(Action action)创建和启动一个Task
            Task task2 = Task.Factory.StartNew(() =>
            {
                Thread.Sleep(100);
                Console.WriteLine($"hello, task2的线程ID为{ Thread.CurrentThread.ManagedThreadId}");
            });

            //3.Task.Run(Action action)将任务放在线程池队列,返回并启动一个Task
            Task task3 = Task.Run<string>(() =>
            {
                Thread.Sleep(100);
              return $"hello, task3的线程ID为{ Thread.CurrentThread.ManagedThreadId}";
            });
            Console.WriteLine("执行主线程!");
            Console.ReadKey();
        }

Task的阻塞方法(Wait/WaitAll/WaitAny)

task.Wait() 表示等待task执行完毕,功能类似于thead.Join(); Task.WaitAll(Task[] tasks) 表示只有所有的task都执行完成了再解除阻塞;
Task.WaitAny(Task[] tasks) 表示只要有一个task执行完毕就解除阻塞

//阻塞主线程。task1,task2都执行完毕再执行主线程
            //执行【task1.Wait();task2.Wait();】可以实现相同功能
            Task.WaitAll(new Task[] { taskwait1, taskwait2 });

使用后 当前线程阻塞 等 使用的线程结束
 如果将的WaitAll换成WaitAny,那么任一task执行完毕就会解除线程阻塞,执行结果是?

Task的延续操作(WhenAny/WhenAll/ContinueWith)

//task1,task2执行完了后执行后续操作
            Task.WhenAll(task, task2).ContinueWith((t) =>
            {
                Thread.Sleep(100);
                Console.WriteLine("执行后续操作完毕!");
            });

            //通过TaskFactroy实现   等待完成后执行后续的线程
            Task.Factory.ContinueWhenAll(new Task[] { task, task2 }, (t) =>
             {
                 Console.WriteLine($"hello, task ContinueWhenAll的线程ID为{Thread.CurrentThread.ManagedThreadId}");
             });

Task的任务取消(CancellationTokenSource)

你可能感兴趣的:(c#,开发语言)