Task - 基于线程池的任务(在 System.Threading.Tasks 命名空间下)

  • 多 Task 的并行执行
  • Parallel - 并行计算(在 System.Threading.Tasks 命名空间下)

示例
1、演示 Task(基于线程池的任务)的基本应用
Thread/Tasks/TaskDemo.xaml

<Pagex:Class="XamlDemo.Thread.Tasks.TaskDemo"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="using:XamlDemo.Thread.Tasks"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"mc:Ignorable="d"><Grid Background="Transparent"><StackPanel Margin="120 0 0 0"><TextBlock Name="lblMsg" FontSize="14.667" /><Button Name="btnCreateTask" Content="执行一个没有返回值的任务" Click="btnCreateTask_Click_1" Margin="0 10 0 0" /><Button Name="btnCancelTask" Content="取消“执行一个没有返回值的任务”" Click="btnCancelTask_Click_1" Margin="0 10 0 0" /><Button Name="btnCreateTaskWithReturn" Content="执行一个带返回值的任务" Click="btnCreateTaskWithReturn_Click_1" Margin="0 30 0 0" /><Button Name="btnCancelTaskWithReturn" Content="取消“执行一个带返回值的任务”" Click="btnCancelTaskWithReturn_Click_1" Margin="0 10 0 0" /></StackPanel></Grid>
</Page>

Thread/Tasks/TaskDemo.xaml.cs

/** Task - 基于线程池的任务(在 System.Threading.Tasks 命名空间下)*/using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using System.Threading.Tasks;
using System.Threading;
using Windows.UI.Core;namespace XamlDemo.Thread.Tasks
{public sealed partial class TaskDemo : Page{/** CancellationTokenSource - 用于取消 CancellationToken *     Token - 一个 CancellationToken 类型的对象,用于关联 Task*     IsCancellationRequested - 是否收到了取消操作的请求*     Cancel() - 发出取消操作的请求*     * CancellationToken - 用于关联 Task,以便取消 Task*     IsCancellationRequested - 是否收到了取消操作的请求*     WaitHandle - 信号,可以通过 WaitHandle.WaitOne() 在当前线程等待*     ThrowIfCancellationRequested() - 如果收到了取消操作的请求,则抛出一个 OperationCanceledException 异常*/private CancellationTokenSource _cts;public TaskDemo(){this.InitializeComponent();}private void btnCreateTask_Click_1(object sender, RoutedEventArgs e){_cts = new CancellationTokenSource();// 实例化一个 Task,可随时通过 task.Status 获取任务状态Task task = new Task((ctx) => // 任务所调用的方法,没有返回值{// 在当前线程上阻塞 3000 毫秒(当收到取消请求时会发出信号,停止阻塞)_cts.Token.WaitHandle.WaitOne(3000);// 收到取消操作的请求后抛出一个 OperationCanceledException 异常,其会导致 task.IsCanceled 的值变为 true// 此处的代码等同于 _cts.Token.ThrowIfCancellationRequested();if (_cts.IsCancellationRequested)throw new OperationCanceledException(_cts.Token);},null, // 上下文对象,task.AsyncState 可获取到此对象,上面的 ctx 也可获取到此对象_cts.Token // 关联的 CancellationToken 对象,用于取消操作);// 开始执行任务task.Start();// task.Wait(); 在当前线程上等待任务执行完lblMsg.Text = "执行了一个没有返回值的任务,3 秒后执行完毕";// 任务执行完毕后的处理(注:ContinueWith 方法支持任意次回调,即可以写多个 task.ContinueWith() 都会被回调)task.ContinueWith((ctx) => // 任务执行完毕后所调用的方法{if (ctx.IsCanceled) // 任务被取消{var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "取消了“执行一个没有返回值的任务”";});}if (ctx.IsFaulted) // 任务发生了一个未处理异常{var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "“执行一个没有返回值的任务”发生了一个未处理异常";});}if (ctx.IsCompleted) // 任务已完成(任务成功地执行完毕或被取消或发生了未处理异常都会 ctx.IsCompleted == true){var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "“执行一个没有返回值的任务”执行完成,taskId: " + ctx.Id.ToString();});}});}private void btnCancelTask_Click_1(object sender, RoutedEventArgs e){// 发出取消操作的请求_cts.Cancel();// _cts.CancelAfter(1000); // 1000 毫秒后发出取消操作的请求}private void btnCreateTaskWithReturn_Click_1(object sender, RoutedEventArgs e){_cts = new CancellationTokenSource();Func<object, string> handler = delegate(object state) // state 是传递过来的上下文对象{// 在当前线程上阻塞 3000 毫秒(当收到取消请求时会发出信号,停止阻塞)_cts.Token.WaitHandle.WaitOne(3000);// 收到取消操作的请求后抛出一个 OperationCanceledException 异常,其会导致 task.IsCanceled 的值变为 true// 此处的代码等同于 _cts.Token.ThrowIfCancellationRequested();if (_cts.IsCancellationRequested)throw new OperationCanceledException(_cts.Token);return "我是“执行一个带返回值的任务”的返回值";};// Task.Factory.StartNew() - 创建任务并马上执行,可随时通过 task.Status 获取任务状态// Task.Run() 同样是创建任务并马上执行Task<string> task = Task.Factory.StartNew<string>(handler, // 任务所调用的方法,带返回值null, // 上下文对象,task.AsyncState 可获取到此对象_cts.Token // 关联的 CancellationToken 对象,用于取消操作);lblMsg.Text = "执行了一个带返回值的任务,3 秒后执行完毕";// 任务执行完毕后的处理(注:ContinueWith 方法支持任意次回调,即可以写多个 task.ContinueWith() 都会被回调)task.ContinueWith((ctx) =>{if (ctx.IsCanceled) // 任务被取消{var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "取消了“执行一个带返回值的任务”";});}if (ctx.IsFaulted) // 任务发生了一个未处理异常{var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "“执行一个带返回值的任务”发生了一个未处理异常";});}if (ctx.IsCompleted) // 任务已完成(任务成功地执行完毕或被取消或发生了未处理异常都会 ctx.IsCompleted == true){var ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;lblMsg.Text += "“执行一个带返回值的任务”执行完成,taskId: " + ctx.Id.ToString();});// 当任务成功地执行完毕时,输出任务的返回值if (!ctx.IsCanceled && !ctx.IsFaulted){ignored = Dispatcher.RunAsync(CoreDispatcherPriority.High,() =>{lblMsg.Text += Environment.NewLine;// 任务的返回值lblMsg.Text += ctx.Result;});}}});}private void btnCancelTaskWithReturn_Click_1(object sender, RoutedEventArgs e){// 发出取消操作的请求_cts.Cancel();// _cts.CancelAfter(1000); // 1000 毫秒后发出取消操作的请求}}
}

2、演示多 Task 的并行执行
Thread/Tasks/MultiTask.xaml

<Pagex:Class="XamlDemo.Thread.Tasks.MultiTask"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="using:XamlDemo.Thread.Tasks"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"mc:Ignorable="d"><Grid Background="Transparent"><StackPanel Margin="120 0 0 0"><TextBlock Name="lblMsg" FontSize="14.667" /><Button Name="btnCreateMultiTask" Content="任务并行执行" Click="btnCreateMultiTask_Click_1" Margin="0 10 0 0" /></StackPanel></Grid>
</Page>

Thread/Tasks/MultiTask.xaml.cs

/** 演示多 Task 的并行执行* * 注:* 本例中同时创建了三个任务 task1, task2, task3,但是由于 Task 是基于线程池的,所以三个任务的启动时间是不一样的,启动顺序是不一定的* 启动顺序可能是 task1->task2->task3,也可能是 task3->task2->task1,也可能是 task2->task3->task1,等等等等都有可能,是不一定的*/using System;
using System.Threading.Tasks;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;namespace XamlDemo.Thread.Tasks
{public sealed partial class MultiTask : Page{private static int _count = 0;public MultiTask(){this.InitializeComponent();}private void btnCreateMultiTask_Click_1(object sender, RoutedEventArgs e){// 创建并执行任务1Task task1 = Task.Run(() =>{new System.Threading.ManualResetEvent(false).WaitOne(3000);System.Threading.Interlocked.Increment(ref _count);});// 创建并执行任务2Task task2 = Task.Run(() =>{new System.Threading.ManualResetEvent(false).WaitOne(3000);System.Threading.Interlocked.Increment(ref _count);});// 创建并执行任务3Task task3 = Task.Run(() =>{new System.Threading.ManualResetEvent(false).WaitOne(3000);System.Threading.Interlocked.Increment(ref _count);});// 将所有任务合成一个 Task 对象,不会阻塞 UI 线程,通过 task.ContinueWith() 获取结果Task task = Task.WhenAll(task1, task2, task3);// Task.WaitAll(task1, task2, task3); 等待所有任务完成,会阻塞 UI 线程DateTime dt = DateTime.Now;// task 执行完毕后的处理,即所有任务执行完毕后的处理task.ContinueWith((ctx) =>{var ignored = Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High,() =>{lblMsg.Text = "count: " + _count.ToString() + ", 执行时间: " + (DateTime.Now - dt).TotalSeconds.ToString() + "秒";});});}}
}

3、演示 Parallel(并行计算)的基本应用
Thread/Tasks/ParallelDemo.xaml

<Pagex:Class="XamlDemo.Thread.Tasks.ParallelDemo"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="using:XamlDemo.Thread.Tasks"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"mc:Ignorable="d"><Grid Background="Transparent"><StackPanel Margin="120 0 0 0"><TextBlock Name="lblMsg1" FontSize="14.667" /><TextBlock Name="lblMsg2" FontSize="14.667" /><Button Name="btnCreateParallel" Content="执行一个并行运算(Parallel)" Click="btnCreateParallel_Click_1" Margin="0 10 0 0" /><Button Name="btnCancelParallel" Content="取消" Click="btnCancelParallel_Click_1" Margin="0 10 0 0" /></StackPanel></Grid>
</Page>

Thread/Tasks/ParallelDemo.xaml.cs

/** Parallel - 并行计算(在 System.Threading.Tasks 命名空间下)* * Parallel.For() - for 循环的并行运算 * Parallel.ForEach() - foreach 循环的并行运算 * Parallel.Invoke() - 并行调用多个 Action* PLINQ - LINQ to Object 的并行运算* * * 本例通过 Parallel.Invoke() 来演示并行运算* 其它并行运算的说明参见:http://www.cnblogs.com/webabcd/archive/2010/06/03/1750449.html*/using System.Threading;
using System.Threading.Tasks;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;namespace XamlDemo.Thread.Tasks
{public sealed partial class ParallelDemo : Page{private CancellationTokenSource _cts;public ParallelDemo(){this.InitializeComponent();}private void btnCreateParallel_Click_1(object sender, RoutedEventArgs e){if (_cts != null)_cts.Cancel();_cts = new CancellationTokenSource();// Parallel 的相关配置ParallelOptions parallelOptions = new ParallelOptions() {CancellationToken = _cts.Token, // Parallel 关联的 CancellationToken 对象,用于取消操作MaxDegreeOfParallelism = 10 // Parallel 的最大并行数};// 并行执行多个 Action(不支持 Func)Parallel.Invoke(parallelOptions,() =>Task1(parallelOptions.CancellationToken),() =>Task2(parallelOptions.CancellationToken));}// Action 1private void Task1(CancellationToken token){Task task = Task.Factory.StartNew(() =>{int count = 0;// 未被取消则一直运行while (!token.IsCancellationRequested){count++;var ignored = Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High,() =>{lblMsg1.Text = "count1: " + count.ToString();});token.WaitHandle.WaitOne(100);}},token);}// Action 2private void Task2(CancellationToken token){Task task = Task.Factory.StartNew(() =>{int count = 0;// 未被取消则一直运行while (!token.IsCancellationRequested){count++;var ignored = Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High,() =>{lblMsg2.Text = "count2: " + count.ToString();});token.WaitHandle.WaitOne(100);}},token);}// 取消并行运算private void btnCancelParallel_Click_1(object sender, RoutedEventArgs e){if (_cts != null)_cts.Cancel();}}
}

转载于:https://www.cnblogs.com/ansen312/p/5942882.html

多线程之任务: Task 基础, 多任务并行执行, 并行运算(Parallel)相关推荐

  1. spring 定时任务 多任务并行执行,多任务多线程 单任务单线程执行实现细节

    前提:spring 定时任务,默认是多任务单线程执行,也就是串行执行的 当前需求: 1. 多任务多线程执行(不同的定时任务并行执行) 2.同一个定时任务单线程执行(保证一个定时任务A在执行完成前,A的 ...

  2. C# 多线程六之Task(任务)三之任务工厂

    1.知识回顾,简要概述 前面两篇关于Task的随笔,C# 多线程五之Task(任务)一 和 C# 多线程六之Task(任务)二,介绍了关于Task的一些基本的用法,以及一些使用的要点,如果都看懂了,本 ...

  3. JAVA-多线程 三 {多线程状态}JAVA从基础开始 -- 3

    JAVA-多线程 三 {多线程状态}(JAVA从基础开始 -- 3 线程状态 停止方法_stop (舍弃) 休眠状态_sleep 线程礼让_yield 线程强制执行_ join 线程状态观测_Thre ...

  4. .NET 并行(多核)编程系列之六 Task基础部分完结篇

    .NET 并行(多核)编程系列之六 Task基础部分完结篇 前言:之前的文章介绍了了并行编程的一些基本的,也注重的讲述了Task的一些使用方法,本篇很短,将会结束Task的基础知识的介绍. 本篇的主要 ...

  5. 【转】细说.NET中的多线程 (三 使用Task)

    上一节我们介绍了线程池相关的概念以及用法.我们可以发现ThreadPool. QueueUserWorkItem是一种起了线程之后就不管了的做法.但是实际应用过程,我们往往会有更多的需求,比如如何更简 ...

  6. C# 4.0 新特性之并行运算(Parallel)

    介绍 C# 4.0 的新特性之并行运算 Parallel.For - for 循环的并行运算 Parallel.ForEach - foreach 循环的并行运算 Parallel.Invoke - ...

  7. Java 多线程(一) 基础知识与概念

    多线程Multi-Thread 基础 线程概念 线程就是程序中单独顺序的流控制. 线程本身不能运行,它只能用于程序中. 说明:线程是程序内的顺序控制流,只能使用分配给程序的资源和环境. 进程 进程:执 ...

  8. springboot 多任务并行执行

    @ComponentScan(basePackages = { "com.meadin.agent" }) @EnableApolloConfig @EnableAsync // ...

  9. Swift5多线程系列一GCD基础篇

    Swift5多线程系列-基础概念篇 iOS开发,多线程开发常用GCD,swift也如是;swift的GCD,使用比OC上更加简单易上手; GCD基础篇目录 Swift5多线程系列-基础概念篇 基础篇 ...

最新文章

  1. php的webservice的wsdl的XML无法显示
  2. Xamarin Android开发实战(上册)
  3. java ee s2sh复习题_JavaEESSH框架答案试题题目及答案,期末考试题库,章节测验答案...
  4. 求最大公约数的设计与C语言实现
  5. 【147天】尚学堂高淇Java300集视频精华笔记(108-109)
  6. 向量的大小和方向,零向量的方向_3
  7. 省一计算机考试题库Excel,计算机等级考试省一级省计算机等级考试题库.doc
  8. Python成绩单雷达图
  9. J2SE下的路径问题
  10. SSH免密登陆:Win登陆linux
  11. python判断素数(质数):for-else循环的理解与示例应用
  12. 一键还原的GHO文件夹打开方法(转载)
  13. 基于微服务的个人博客系统
  14. 万洲金业集结全面行业优势 打造贵金属产品理财矩阵
  15. Arduino开发(二)_基于Arduino UNO开发板的RGB灯光控制方法
  16. PI3体验之无线网AP模式设定及热点分享
  17. Dcloud 全栈之旅1-1 组件-基础
  18. Integer装箱拆箱、参数传递
  19. Android掌中游斗地主游戏源码完整版
  20. 利用XLSX工具库实现xlsx或xls的上传

热门文章

  1. Java类的执行顺序
  2. HDOJ 1753 明朝A+B
  3. 诗与远方:无题(四十八)
  4. 今年四月份,发现我的文章被人全部复制了,抄到博客园了,连原文出处都没有,就算你写个参考文章也行呀
  5. 集成 Tomcat、 Servlet 的生命周期
  6. 1的准确率_库存准确率总是100%正常吗?
  7. C语言按位运算符 按位逻辑运算 移位运算 及其用法
  8. 描写计算机老师上课的神态,请你用一段话描写一位老师上课的情景,注意抓住神态语言动作等细节...
  9. html5 标准结构_IT兄弟连 HTML5教程 HTML文件的主体结构
  10. Linux运维面试题之--网页打开缓慢如何优化