Parallel.For/ForEach是数据层面的并行,本文所讲的Task是将不同的操作并行执行,本文主要内容:

  1. Task的工作模型
  2. 初始化Task
  3. 完成Task
  4. 取消Task

一、Task工作模型

.Net中Task的工作模式是Fork/Join或者Master/Worker模式。核心思想是Master负责接受Client的请求,并且负责将请求分配给最终的Wroker,Worker执行完自己的工作后分别返回给Master。由Master汇总最终的结果并且返回给Client。

在.Net的Task并行编程中。一个Worker代表一个Task。

二、初始化Task

2.1Parallel.Invoke

Parallel.Invoke是最简单的办法Task并行编程模式。

2.2 TaskFactory.StartNew

该方法会创建一个Task用于执行作为参数的方法。

    class TaskDemo
{
public void Action1()
{
Console.WriteLine("in action1");
} public void Action2()
{
Console.WriteLine("in action2");
} public void StartTasks()
{
var task1 = Task.Factory.StartNew(Action1);
var task2 = Task.Factory.StartNew(Action2);
Task.WaitAll(task1, task2);
}
}

以上代码使用TaskFactory.StartNew方法创建了两个Task。task1用于执行Action1,task2用于执行Action2.

StartNew只是创建了一个task,并将该task加入到一个工作队列(work queue),当时该Task并没有马上执行,task什么时候执行是由TaskScheduler决定。TaskScheduler会将需要执行的task从中拿出来,然后才开始执行。(以上代码使用的是默认TaskScheduler)

TaskScheduler很可能马上执行,也有可能在未来的某一个特定时间点进行执行,取决于调度算法,以及CPU资源等。

三、Task的完成

刚开始说了。Task编程使用的是Master/Worker模式,该模式中最后一点是Worker最终会将结果返回给Master。由Master统一将结果进行汇总。在Task编程中有两个方法:

  1. Task.WaitAll。等待所有的Task(worker)完成。
  2. Task.WaitAny,等待任何一个Task完成即可。

3.1 Task.WaitAll

上面2.2的代码中已经使用了WaitAll,该方法将会等待两个Action完成之后才会进行返回,将上面的方法做一点改变。

class TaskDemo
{
public void Action1()
{
Thread.Sleep();
Console.WriteLine("in action1");
} public void Action2()
{
Thread.Sleep();
Console.WriteLine("in action2");
} public void StartTasks()
{
var task1 = Task.Factory.StartNew(Action1);
var task2 = Task.Factory.StartNew(Action2);
Task.WaitAll(task1, task2);
Console.WriteLine("Finished");
}
}

WaitAll之后再打印出”Finished“,按照WaitAll的定义,Finished永远是最后打印出来的字符串。

3.2 Task.WaitAny

将上面代码的WaitAll修改成WaitAny

       public void StartTasks()
{
var task1 = Task.Factory.StartNew(Action1);
var task2 = Task.Factory.StartNew(Action2);
Task.WaitAny(task1, task2);
Console.WriteLine("Finished");
}

最终运行结果:

可以看出使用了WaitAny后,没有等待Task2执行完毕,程序就回到了主线程,先打印出了Finished。

四、取消Task

4.1 取消流程

Task取消使用一个叫做coorperative cancellation的模型进行Task取消。主要使用CancellationTokenSource完成。该对象有一个CancellactionToken。当StartNew一个Task时候,可以将toker传给被创建的task。当CancellationTokenSource调用Cancel后,Task对应的Token状态将会变为取消(Canceled),Task的状态也会变为取消。这时候如果Task还没有启动,Task将不会再执行任务。

当然最后在每个Task内部也对Token进行判断,如果token已经取消,则不再执行当前Action(有些task可能在CancellactionToke被取消之前已经启动了),修改一下执行图:

4.2 演示代码

   class TaskDemo
{
public void Action1(CancellationTokenSource cts)
{
if(cts.IsCancellationRequested)
{
return;
}
Console.WriteLine("in action1");
} public void Action2(CancellationTokenSource cts)
{
Thread.Sleep();
if (cts.IsCancellationRequested)
{
Console.WriteLine("action2 is canceled");
return;
}
Console.WriteLine("in action2");
} public void StartTasks()
{
CancellationTokenSource cts = new CancellationTokenSource();
var task1 = Task.Factory.StartNew(() => Action1(cts), cts.Token);
var task2 = Task.Factory.StartNew(() => Action2(cts), cts.Token);
Task.WaitAny(task1, task2);
cts.Cancel();
Console.WriteLine("Finished");
}
}

4.3 运行结果

上面的运行结果有可能“action2 is canceled"这句话不会打印出来,因为有可能在Task2执行之前cts已经取消了。会进入流程图中第一个If判断点==》Not will run task

Parallel Programming-Task Base的更多相关文章

  1. Task Cancellation: Parallel Programming

    http://beyondrelational.com/modules/2/blogs/79/posts/11524/task-cancellation-parallel-programming-ii ...

  2. Notes of Principles of Parallel Programming - TODO

    0.1 TopicNotes of Lin C., Snyder L.. Principles of Parallel Programming. Beijing: China Machine Pres ...

  3. Samples for Parallel Programming with the .NET Framework

    The .NET Framework 4 includes significant advancements for developers writing parallel and concurren ...

  4. Introduction to Multi-Threaded, Multi-Core and Parallel Programming concepts

    https://katyscode.wordpress.com/2013/05/17/introduction-to-multi-threaded-multi-core-and-parallel-pr ...

  5. Fork and Join: Java Can Excel at Painless Parallel Programming Too!---转

    原文地址:http://www.oracle.com/technetwork/articles/java/fork-join-422606.html Multicore processors are ...

  6. A Pattern Language for Parallel Programming

    The pattern language is organized into four design spaces.  Generally one starts at the top in the F ...

  7. 4.3 Reduction代码(Heterogeneous Parallel Programming class lab)

    首先添加上Heterogeneous Parallel Programming class 中 lab: Reduction的代码: myReduction.c // MP Reduction // ...

  8. Parallel Programming for FPGAs 学习笔记(1)

    Parallel Programming for FPGAs 学习笔记(1)

  9. Parallel Programming AND Asynchronous Programming

    https://blogs.oracle.com/dave/ Java Memory Model...and the pragmatics of itAleksey Shipilevaleksey.s ...

  10. 多线程Parallel和Task

    不管是Parallel还是Task,最里面都是线程池(里面是线程)当开启多个任务后,系统会根据当前的线程池的资源进行分配,任务则进行等待Parallel可以对系统的CPU进行设置,可以最大程度上榨干系 ...

随机推荐

  1. 开始翻译《Beginning SharePoint 2013 Development》

    伙同涂曙光@kaneboy 和柴晓伟@WindieChai 翻译Beginning SharePoint 2013 Development 作者是Steve Fox,传说中的Andrew Connel ...

  2. 九度OJ 1351:数组中只出现一次的数字 (位运算)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3098 解决:906 题目描述: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 输入: 每个 ...

  3. netstat命令简单使用

    1.适用范围 该命令用于打印网络连接.路由表.接口统计.伪装连接.多播成员等信息. (netstat已经过时,现在使用ss命令,所以本文不会作过多翻译,只着重一些重要部分) 2.语法概览 netsta ...

  4. maven filters 和 resource

    1 filter 1.1 用途 对多个配置文件进行选择. 1.2 选择的依据 1.3 使用的方式 第一,在<resource>标签下面加<filtering>标签,并且< ...

  5. mybatis generator的用法

    1 自动生成代码 配置数据库 自动生成三个文件: 第一,java bean文件: 第二,java bean对应的dao文件,但是这里的dao只是一个接口: 第三,mybatis需要的Mapper文件: ...

  6. ElasticSearch(二十一)正排和倒排索引

    1.区别 搜索的时候,要依靠倒排索引:排序的时候,需要依靠正排索引,看到每个document的每个field,然后进行排序,所谓的正排索引,其实就是doc values 在建立索引的时候,一方面会建立 ...

  7. SM30维护视图创建【转】

           在SAP中,经常需要自定义数据库表.而且可能需要人工维护数据库表中的数据,可以通过SM30进行维护数据:但是SM30事务的权限太大,不适宜将SM30直接分配:因此,可以通过给维护表分配事 ...

  8. VMware Integrated OpenStack (VIO)简介

    VMware Integrated OpenStack是一款由VMware提供支持的OpenStack发行版软件,用于帮助IT在现有的VMware基础架构之上更加轻松地运行基于生产级OpenStack ...

  9. 3.26课·········window.document对象

    1.Window.document对象 一.找到元素:    docunment.getElementById("id"):根据id找,最多找一个:    var a =docun ...

  10. 牛客小白月赛1 C 分元宵【快速幂】

    题目链接 https://www.nowcoder.com/acm/contest/85/C 思路 有 A 种 元宵馅,B 种元宵皮 所以 我们可以认为 有Q = A * B 种 元宵 有 C 张桌子 ...