一起谈.NET技术,.Net4.0 Parallel编程(四)Task 上

简介:   在之前的文章中,已经介绍过了Parallel Loop(上、中、下)的相关内容。本篇文章中会就Task基础部分进行些介绍。  初识Task  首先我们来构建一个简单的Task的Demo:static void Main(string[] args){ Task.Factory.StartNew(() => { Console.WriteLine("Hello word!"); }); Console.Read();}  在上面这段代码中我们构建出了一段非常简单的使用Task类的代码,通过其Factory属性的创建出一个Task。

  在之前的文章中,已经介绍过了Parallel Loop()的相关内容。本篇文章中会就Task基础部分进行些介绍。

  初识Task

  首先我们来构建一个简单的Task的Demo:

 
 
static void Main( string [] args)
{
Task.Factory.StartNew(()
=>
{
Console.WriteLine(
" Hello word! " );
});
Console.Read();
}

  在上面这段代码中我们构建出了一段非常简单的使用Task类的代码,通过其Factory属性的创建出一个Task。其运行结果可想而知。其实上面的代码跟:

 
 
static void Main( string [] args)
{
Task task
= new Task(() =>
{
Console.WriteLine(
" Hello,Word! " );
});
task.Start();
Console.Read();
}

  是一样的,只是StartNew方法直接构建出了一个Task之后又调用了其Start方法。在Task内部执行的内容我们称作为Task的Body,Task提供了多个初始化重载的方法。我们来看下面一个示例:

 
 
static void Main( string [] args)
{
Task task1
= new Task(() =>
{
Console.WriteLine(
" Message: Say \ " Hello\ " from task1 " );
});
Task task2
= new Task( new Action < object > (printMessage),
" Say \ " Hello\ " from task2 " );

Task task3
= new Task((obj) => { printMessage(obj); },
" Say \ " Hello\ " from task3 " );

Task task4
= new Task((obj) => { Console.WriteLine( " Message: {0} " , obj); },
" Say \ " Hello\ " from task4 " );

task1.Start();
task2.Start();
task3.Start();
task4.Start();
Console.Read();
}

  上面的例子中使用了重载方法的State参数,其运行结果:

image  好像结果跟我们想象的优点不太一样,其实我们仔细想想就可以理解了。

  返回值

 
 
static void Main( string [] args)
{
var loop
= 0 ;
var task1
= new Task < int > (() =>
{
for (var i = 0 ; i < 1000 ; i ++ )
loop
+= i;
return loop;
});
task1.Start();
var loopResut
= task1.Result;
var task2
= new Task < long > (obj =>
{
long res = 0 ;
var looptimes
= ( int )obj;
for (var i = 0 ; i < looptimes; i ++ )
res
+= i;
return res;
},loopResut);

task2.Start();
var resultTask2
= task2.Result;

Console.WriteLine(
" Task1's result:{0}\nTask2's result:{1} " ,
loopResut,
resultTask2);
Console.ReadKey();
}

  运行的结果:

image  在这里要说的是,Result属性的获取是在一个Task运行完成才会获取的,所以上面的task2是在task1运行完成后,才开始运行,也就是说上面的两个result的值不管运行多少次都是不会变的。其中我们也可以通过CurrentId来获取当前运行的Task的编号,但是要注意的一点,如果我们再Task的body之外获取他将会返回null。

  总结

  在这篇文章中我们看到了如何创建一个Task,以及使用其返回值的属性的介绍。下篇文中我们会看下如何取消一个Task。

目录
相关文章
|
4月前
|
算法 Java 调度
|
4月前
|
人工智能 机器人 C#
Windows编程课设(C#)——基于WPF和.net的即时通讯系统(仿微信)
一款参考QQ、微信的即时通讯软件。采用CS结构,客户端基于.Net与WPF开发,服务端使用Java开发。
|
7月前
|
人工智能 自然语言处理 程序员
.NET开发工作效率提升利器 - CodeGeeX AI编程助手
.NET开发工作效率提升利器 - CodeGeeX AI编程助手
138 0
|
7月前
|
人工智能 自然语言处理 程序员
.NET开发工作效率提升利器 - CodeGeeX AI编程助手
.NET开发工作效率提升利器 - CodeGeeX AI编程助手
106 1
|
9月前
|
SQL 开发框架 缓存
.NET的并发编程(TPL编程)是什么? (下)
.NET的并发编程(TPL编程)是什么? (下)
|
9月前
|
SQL 开发框架 缓存
|
11月前
|
人工智能 机器人 API
.NET面向AI编程——SK框架(SemanticKernel)的简易入门实践
随着ChatGPT开始在各个领域遍地开花,有关的应用也开始层出不穷。随着微软开源SK框架,无疑是给.NET开发者带来面向AI应用的新机遇。以下内容,通过创建一个简单的prompt开始,开发一个使用SK框架进行开发的入门教程,供参考。
209 0
|
缓存 前端开发 JavaScript
采用.Net Core技术框架开发的医院云LIS平台源码,B/S架构
基于B/S架构的医学实验室检验系统源码,整个系统的运行基于WEB层面,只需要在对应的工作台安装一个浏览器软件有外网即可访问。全套系统采用云部署模式,部署一套可支持多家医院检验科共同使用。 采用.Net Core新的技术框架、DEV报表、前端js封装、分布式文件存储、分布式缓存等,支持LIS独立部署,Docker部署等多种方式。
|
存储 Go 网络架构
Go HTTP 编程 | 02 - net/http 包剖析
Go HTTP 编程 | 02 - net/http 包剖析
Go HTTP 编程 | 02 - net/http 包剖析
C#编程-140:Net.Mail类发送邮件
C#编程-140:Net.Mail类发送邮件
C#编程-140:Net.Mail类发送邮件