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

简介:   Parallel.For  首先先写一个普通的循环:private void NormalFor(){for (var i = 0; i private void ParallelFor(){ Parallel.

  Parallel.For

  首先先写一个普通的循环:

 
 
private void NormalFor()
{
for (var i = 0 ; i < 10000 ; i ++ )
{
for (var j = 0 ; j < 1000 ; j ++ )
{
for (var k = 0 ; k < 100 ; k ++ )
{
DoSomething();
}
}
}
}

  再看一个并行的For语句:

 
 
private void ParallelFor()
{
Parallel.For(
0 , 10000 , i =>
{
for ( int j = 0 ; j < 1000 ; j ++ )
{
for (var k = 0 ; k < 100 ; k ++ )
{
DoSomething();
}
}

});
}

  看下测试方法:

 
 
[TestMethod()]
public void TestForLoop()
{

_StopWatch.Start();
this .NormalFor();
_StopWatch.Stop();
Console.WriteLine(
" NormalForLoop Runned Time:{0} " , _StopWatch.ElapsedMilliseconds);

_StopWatch.Reset();
_StopWatch.Start();
this .ParallelFor();
_StopWatch.Stop();
Console.WriteLine(
" Parallel Loop:{0} " , _StopWatch.ElapsedMilliseconds);
}

  测试结果:

image

  上面的例子中,只是将最外层的For语句替换成了Parallel.For,我们可以看到Parallel执行速度提高了近一倍。下面我把里面的循环也改成并行的:

 
 
private void ParallelNestedFor()
{
Parallel.For(
0 , 10000 , i =>
{
Parallel.For(
0 , 1000 , j =>
{
for (var k = 0 ; k < 100 ; k ++ )
{
DoSomething();
}
});

});
}

  结果:

image

  也许会令我们感到惊讶的是:嵌套Paralled For之后速度并没有更快,反而稍微慢了。其实是这样的,因为我们的示例中大部分操作是在最外层循环,而在并行操作中会需要缓存数据等会浪费一定的性能。当我们把最外层的循环调整成100,中间层为10000时,我们来看下结果:

image

  所以,是否需要嵌套的时候,需要我们根据一些实际情况来决定,不过对于大部分操作,最外层的并行处理已经足够了。

  Parallel.ForEach

  我们来看两段很简单的代码:

 
 
private void NormalForeach()
{
foreach (var file in GetFiles())
{
DoSomething();
}

}

private void ParallelForeach()
{
Parallel.ForEach(GetFiles(), file
=> {
DoSomething();
});
}

  测试的结果:

image

  Foreach的使用跟For使用几乎是差不多了,只是在对非泛型的Collection进行操作的时候,需要通过Cast方法进行转换。

  总结

  在本文中,我们简单的介绍了Parallel.For跟Parallel.Foreach方法的使用,感受了下并行编程给我们带来的速度上的优势,在下篇文章中会介绍如何跳出循环以及一些异常的处理。

目录
相关文章
|
6月前
|
关系型数据库 MySQL 数据库
找不到请求的 .Net Framework Data Provider。可能没有安装
做的一个项目,框架为.net framework 数据库为mysql 出现如标题错误 检查是否安装mysql、是否安装mysql connector net 笔者是因为没有安装后者mysql connector net 下载地址: [mysql connector net](https://downloads.mysql.com/archives/c-net/ "mysql connector net") 笔者安装截图如下: ![请在此添加图片描述](https://developer-private-1258344699.cos.ap-guangzhou.myqcloud.com/c
61 0
|
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类发送邮件