Task类似后台线程。

using System;
using System.Threading;
using System.Threading.Tasks;//引用命名空间 namespace ConsoleApplication3
{
class Program
{
void DownloadFile()
{
Console.WriteLine("任务开始" );
Thread.Sleep();
Console.WriteLine("任务结束");
}
static void Main(string[] args)
{
Program p = new Program();//类的对象,方便引用非静态成员
Task t = new Task(p.DownloadFile);//创建任务
t.Start();
//TaskFactory tf = new TaskFactory();//任务工厂,方便创建多个Task
//Task t = tf.StartNew(p.DownloadFile);
//Task t1 = tf.StartNew(p.DownloadFile);
//Task t2 = tf.StartNew(p.DownloadFile); Console.ReadKey();
}
}
}

先后任务:一个任务依赖于另一个任务。即有先后顺序。使用ContinueWith

后继任务,方法参数不可省略,类似线程池

using System;
using System.Threading;
using System.Threading.Tasks;//引用命名空间 namespace ConsoleApplication3
{
class Program
{
void DoFirst()
{
Console.WriteLine("任务1开始" );
Thread.Sleep();
}
void DoSecond(Task a)//后继任务,参数不可省略,类似线程池
{
Console.WriteLine("任务2开始");
Thread.Sleep();
}
void DoThird(Task a)
{
Console.WriteLine("任务3开始");
Thread.Sleep();
}
static void Main(string[] args)
{
Program p = new Program();//类的对象,方便引用非静态成员
Task t1 = new Task(p.DoFirst);//任务1
Task t11 = t1.ContinueWith(p.DoSecond);//任务1结束后,异步执行后继任务2、3
Task t12 = t1.ContinueWith(p.DoThird);
Task t111 = t11.ContinueWith(p.DoSecond);//任务2结束后,才执行 t1.Start(); Console.ReadKey();
}
}
}

一个任务A中启动一个新任务B,两个任务异步执行,可认为同时执行。

using System;
using System.Threading;
using System.Threading.Tasks;//引用命名空间 namespace ConsoleApplication3
{
class Program
{
void DoFirst()//2s
{
Console.WriteLine("任务1开始");
Task t2 = new Task(DoSecond);//任务1中启动了任务2
t2.Start();//异步执行,可以认为1、2同时启动
Thread.Sleep();
Console.WriteLine("任务1结束");
}
void DoSecond()//5s
{
Console.WriteLine("任务2开始");
Thread.Sleep();
Console.WriteLine("任务2结束");
}
static void Main(string[] args)
{
Program p = new Program();//类的对象,方便调用成员
Task t1 = new Task(p.DoFirst);//任务1启动
t1.Start();
Console.ReadKey();
}
}
}

更深入内容参考:

https://blog.csdn.net/qq3401247010/article/details/81542461

https://blog.csdn.net/EthanWhite/article/details/52171262

任务Task、先后任务的更多相关文章

  1. Concepts:Request 和 Task

    当SQL Server Engine 接收到Session发出的Request时,SQL Server OS将Request和Task绑定,并为Task分配一个Workder.在TSQL Query执 ...

  2. .Net多线程编程—任务Task

    1 System.Threading.Tasks.Task简介 一个Task表示一个异步操作,Task的创建和执行是独立的. 只读属性: 返回值 名称 说明 object AsyncState 表示在 ...

  3. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

  4. windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...

  5. Openstack Periodic Task

    Openstack Periodic Task 周期性任务在各个模块的manager.py(computer,scheduler,cell,network)中添加. 添加方法:在模块manager类实 ...

  6. MapReduce剖析笔记之三:Job的Map/Reduce Task初始化

    上一节分析了Job由JobClient提交到JobTracker的流程,利用RPC机制,JobTracker接收到Job ID和Job所在HDFS的目录,够早了JobInProgress对象,丢入队列 ...

  7. [Java定时器]用Spring Task实现一个简单的定时器.

    今天做一个项目的的时候需要用到定时器功能.具体需求是: 每个月一号触发一次某个类中的方法去拉取别人的接口获取上一个月份车险过期的用户.如若转载请附上原文链接:http://www.cnblogs.co ...

  8. 定时管理器框架-Task.MainForm

    入住博客园4年多了,一直都是看别人的博客,学习别人的知识,为各个默默无私贡献自己技术总结的朋友们顶一个:这几天突然觉得是时候加入该队列中,贡献出自己微弱的力量,努力做到每个月有不同学习总结,知识学习的 ...

  9. Task三个列子的分享

    这次要分享的是C#Task任务的几个列子,感觉最实用的是封装的分页任务执行方法,这个方法步奏也是目前在我工作中执行多任务常用的,不知道各位也有这用的情况,那么开始吧. 1.顺序任务执行 //顺序任务执 ...

  10. webapi+Task并行请求不同接口实例

    标题的名称定义不知道是否准确,不过我想表达的意思就是使用Task特性来同时请求多个不同的接口,然后合并数据:我想这种场景的开发对于对接过其他公司接口的人不会陌生,本人也是列属于之内,更多的是使用最原始 ...

随机推荐

  1. 【0.2】【MySQL】常用监控指标及监控方法(转)

    [MySQL]常用监控指标及监控方法 转自:https://www.cnblogs.com/wwcom123/p/10759494.html  对之前生产中使用过的MySQL数据库监控指标做个小结. ...

  2. HDU1305 Immediate Decodability (字典树

    Immediate Decodability An encoding of a set of symbols is said to be immediately decodable if no cod ...

  3. [BZOJ1576] [BZOJ3694] [USACO2009Jan] 安全路径(最短路径+树链剖分)

    [BZOJ1576] [BZOJ3694] [USACO2009Jan] 安全路径(最短路径+树链剖分) 题面 BZOJ1576和BZOJ3694几乎一模一样,只是BZOJ3694直接给出了最短路树 ...

  4. 集成学习-Boosting 模型深度串讲

    首先强调一下,这篇文章适合有很好的基础的人 梯度下降 这里不系统讲,只介绍相关的点,便于理解后文 先放一个很早以前写的 梯度下降 实现 logistic regression 的代码 def tidu ...

  5. Elasticsearch6.2集群搭建, centos7

    原文地址,转载请注明出处:https://blog.csdn.net/qq_34021712/article/details/79330028   ©王赛超 环境介绍 服务器 是否可以成为主节点 是否 ...

  6. Dubbo消费方服务调用过程源码分析

    参考:dubbo消费方服务调用过程源码分析dubbo基于spring的构建分析Dubbo概述--调用过程dubbo 请求调用过程分析dubbo集群容错机制代码分析1dubbo集群容错策略的代码分析2d ...

  7. O015、OpenStack 架构

    参考https://www.cnblogs.com/CloudMan6/p/5340622.html   终于正式进入OpenStack 部分了.   今天开始正式学习OpenStack,OpenSt ...

  8. jquery 滚动事件-记录自己常用的

    1.h5端页面滑动至第3屏及以后才出现置顶按钮 $(document).scroll(function() { var scroH = $(document).scrollTop(); //滚动高度 ...

  9. Apache(web服务器)与Tomcat(应用服务器)搭建集群

    web服务器:Apache.Nginx.IIS等 应用服务器:Tomcat.JBoss.Weblogic等 现在web服务器和应用服务器其实界限已经不是太清晰了,大部分的应用服务器也包含一些web服务 ...

  10. wampserver2.2 在window2003下的安装的主要问题

    准备安装最新的wampserver 2.2c,   1.安装问题,安装完成后总是无法启动服务   系统事件中提示错误 找不到附属汇编 Microsoft.VC90.CRT,上一个错误是 参照的汇编没有 ...