开发者社区> 狼人2007> 正文

一起谈.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方法的使用,感受了下并行编程给我们带来的速度上的优势,在下篇文章中会介绍如何跳出循环以及一些异常的处理。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
.NET中的异步编程- IO完“.NET技术”成端口以及FileStream.BeginRead
  写这个系列原本的想法是讨论一下.NET中异步编程风格的变化,特别是F#中的异步工作流以及未来的.NET 5.0中的基于任务的异步编程模型。但经过三篇文章后很多人对IO异步背后实现的原理以及为什么这样能提高性能很感兴趣。
670 0
SAS学习笔记之《SAS编程与数据挖掘商业案例》(4)DATA步循环与控制、常用全程语句、输出控制
SAS学习笔记之《SAS编程与数据挖掘商业案例》(4)DATA步循环与控制、常用全程语句、输出控制 1. 各种循环与控制 DO组 创建一个执行语句块 DO循环 根据下标变量重复执行DO和END之间的语句 DO WHILE 重复执行直到条件为假则退出循环 DO UNTIL 重复执行直到条件为真则退出循环 DO OVER 对隐含下标
1330 0
【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航
原文:【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航 《ORACLE PL/SQL编程详解》    系列文章目录导航     ——通过知识共享树立个人品牌。
1029 0
数论 代数 群论 范畴论 与 函数式编程 Haskell, Scala
来自China Scala User Group 微信群的一段话,讲的很有意思,这里摘录一下: 数论 研究一个一个的数特性;Object常用术语: 1, 2, 3, "hello world" 代数 研究数上面的操作的特性;常用术语:+ ,-, * , /, mod, concat, 群论 把代数上面的操作,根据共通的特性,分成一个组(群)一个组(群)的来研究。
1715 0
Java8 CompletableFuture 编程
Java8 CompletableFuture 编程阅读目录 一、简介二、CompletableFuture 使用回到顶部一、简介 所谓异步调用其实就是实现一个无需等待被调用函数的返回值而让操作继续运行的方法。
898 0
+关注
狼人2007
个人对技术的追求:代码少而精捍;思路清晰美观;可扩展好维护;技术驱动商业; 人生格言:只要你有信念,有追求,并且坚持,那你一定比随波逐流,行得远行得正...
3523
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载