Parallel并行编程可以让我们使用极致的使用CPU。并行编程与多线程编程不同,多线程编程无论怎样开启线程,也是在同一个CPU上切换时间片。而并行编程则是多CPU核心同时工作。耗时的CPU计算操作选择并行是明智的。通常情况,每个CPU核心代表一个硬件线程,但超线程技术,可以使一个cpu核心具有两个硬件线程。软件线程顾名思义就是我们在程序中所开启的。

下面看一个最基础的并行编程的例子,也足以体现多核心并行运行的好处,当然微软.NET为我们封装后,我们也不必过多关注底层操作,那我们就看一下运行结果。

static void Main(string[] args)
{
#region 实验1 var watch = Stopwatch.StartNew(); watch.Start(); FirstOption(); SecondOption(); Console.WriteLine("串行编程耗时:{0}", watch.ElapsedMilliseconds); watch.Restart(); Parallel.Invoke(FirstOption, SecondOption); watch.Stop(); Console.WriteLine("并行编程耗时:{0}", watch.ElapsedMilliseconds); Console.Read();
} static void FirstOption()
{
//假装CPU耗时操作
Console.WriteLine("我在时间{0}开始",DateTime.Now);
Thread.Sleep();
Console.WriteLine("我是任务一,耗时3s"); } static void SecondOption()
{
//假装CPU耗时操作
Console.WriteLine("我在时间{0}开始", DateTime.Now);
Thread.Sleep();
Console.WriteLine("我是任务二,耗时5s"); }

看完结果,相信不用我说,你也明白了,并行操作由多核心同时操作。

可能你会问如果我需要执行十几个类似于示例中的Option方法怎么办,那就要看你的核心数量了,如果核心数量不足,并不是所有的操作都是同一秒进行的。

代码就不上了,就是弄了11个option,可以看出我的配置很菜,有些时候同一秒开启只两个option,原因就是另外的option耗时比较长,在占用状态。

下面将介绍Parallel的For循环。并限制其能使用的硬件线程个数。

代码如下:


 var bag = new ConcurrentBag<int>();
GC.Collect();
watch.Start(); ParallelOptions options = new ParallelOptions(); //设置硬件线程数
options.MaxDegreeOfParallelism = ;
//options.MaxDegreeOfParallelism = 2;
//options.MaxDegreeOfParallelism = 3;
//options.MaxDegreeOfParallelism = 4; Parallel.For(, , options, i =>
{
bag.Add(i);
});
//for (int i = 0; i < 20000000; i++)
//{
// bag.Add(i);
//}
watch.Stop();
Console.WriteLine("并行计算:集合有:{0},使用的时间:{1}", bag.Count, watch.ElapsedMilliseconds);
Console.ReadKey();


我分别使用1,2,3个硬件线程数和4个硬件线程数作比较。效果很明显!

关于Parallel的For循环,实际上和我们普通的串行编程功能一样,只不过在并行编程中,.NET底层帮助我们大限度的使用了CPU而已。如果你不限制硬件线程数,通常会尽最大可能使用资源。

同时我也测试了串行代码。

另外受环境影响,并行的优势并非绝对。

2016.10.07补充。

在服务器应用上,通常也就是我们的web应用,很多时候使用并行编程会降低你的处理性能,也许在你的用户特别少的情况下会有些作用。

并行编程主要应该是用在桌面应用这种,让用户的机器完全利用起来。

Parallel并行编程初步的更多相关文章

  1. C# IEnumerable,Lambda表达式和 Parallel并行编程的用法

    以前一直主要做C++和C方面的项目,对C#不太了解熟悉,但听说不难,也就一直没有在意学习C#方面的知识.今天有个C#项目,需要做些应用的扩展,同时修改一些bug.但看了C#代码,顿时觉得有些不适应了. ...

  2. Parallel并行编程

    Parallel并行编程 Parallel并行编程可以让我们使用极致的使用CPU.并行编程与多线程编程不同,多线程编程无论怎样开启线程,也是在同一个CPU上切换时间片.而并行编程则是多CPU核心同时工 ...

  3. .Net并行编程

    1.什么是线程?线程和进程的区别是什么? 线程是程序执行的最小单元. 区别: 进程是操作系统进行资源处理和分配的最小单位,而一个进程可以包含多个线程,并共享进程的资源. 2.什么是多线程?为什么设计多 ...

  4. Task C# 多线程和异步模型 TPL模型 【C#】43. TPL基础——Task初步 22 C# 第十八章 TPL 并行编程 TPL 和传统 .NET 异步编程一 Task.Delay() 和 Thread.Sleep() 区别

    Task C# 多线程和异步模型 TPL模型   Task,异步,多线程简单总结 1,如何把一个异步封装为Task异步 Task.Factory.FromAsync 对老的一些异步模型封装为Task ...

  5. C#~异步编程再续~大叔所理解的并行编程(Task&Parallel)

    返回目录 并行这个概念出自.net4.5,它被封装在System.Threading.Tasks命名空间里,主要提供一些线程,异步的方法,或者说它是对之前Thread进行的二次封装,为的是让开发人员更 ...

  6. 【读书笔记】.Net并行编程高级教程--Parallel

    一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控>这本书中也多次提到并发,不管是计算机 ...

  7. C#并行编程-Parallel

    菜鸟学习并行编程,参考<C#并行编程高级教程.PDF>,如有错误,欢迎指正. 目录 C#并行编程-相关概念 C#并行编程-Parallel C#并行编程-Task C#并行编程-并发集合 ...

  8. C#并行编程中的Parallel.Invoke

    一.基础知识 并行编程:并行编程是指软件开发的代码,它能在同一时间执行多个计算任务,提高执行效率和性能一种编程方式,属于多线程编程范畴.所以我们在设计过程中一般会将很多任务划分成若干个互相独立子任务, ...

  9. Net并行编程高级教程--Parallel

    Net并行编程高级教程--Parallel 一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控 ...

随机推荐

  1. 使用 ServiceStack 构建跨平台 Web 服务

    本文主要来自MSDN杂志<Building Cross-Platform Web Services with ServiceStack>,Windows Communication Fou ...

  2. 使用Akka.net开发第一个分布式应用

    系列主题:基于消息的软件架构模型演变 既然这个系列的主题是"基于消息的架构模型演变",少不了说说Actor模型.Akka.net是一个基于Actor模型的分布式框架.如果你对分布式 ...

  3. iOS开发系列--Objective-C之KVC、KVO

    概述 由于ObjC主要基于Smalltalk进行设计,因此它有很多类似于Ruby.Python的动态特性,例如动态类型.动态加载.动态绑定等.今天我们着重介绍ObjC中的键值编码(KVC).键值监听( ...

  4. [SDK2.2]Windows Azure Storage (15) 使用WCF服务,将本地图片上传至Azure Storage (上) 服务器端代码

    <Windows Azure Platform 系列文章目录> 这几天工作上的内容,把项目文件和源代码拿出来给大家分享下. 源代码下载:Part1 Part2 Part3 我们在写WEB服 ...

  5. Inter Core CPU 型号的尾字母含义

    Inter Core CPU 型号的尾字母含义: M:表示移动处理器(Mobile Processor):QM:四核移动处理器(Quad Mobile Processor):U:超低电压处理器(Ult ...

  6. hibernate注解方法使用总结(转)

    原博文地址:http://blog.sina.com.cn/s/blog_935ebb670101dnre.html 1.类级别注解 @Entity     映射实体类 @Table    映射数据库 ...

  7. Html 特殊符号

    HTML特殊符号对照表 特殊符号 命名实体 十进制编码 特殊符号 命名实体 十进制编码 Α Α Α Β Β Β Γ Γ Γ Δ Δ Δ Ε Ε Ε Ζ Ζ Ζ Η Η Η Θ Θ Θ Ι Ι Ι Κ ...

  8. Android仿微信拍摄短视频

    近期做项目需要添加上传短视频功能,功能设置为类似于微信,点击开始拍摄,设置最长拍摄时间,经过研究最终实现了这个功能,下面就和大家分享一下,希望对你有帮助. 1.视频录制自定义控件: /** * 视频播 ...

  9. .NET平台开源项目速览(11)KwCombinatorics排列组合使用案例(1)

    今年上半年,我在KwCombinatorics系列文章中,重点介绍了KwCombinatorics组件的使用情况,其实这个组件我5年前就开始用了,非常方便,麻雀虽小五脏俱全.所以一直非常喜欢,才写了几 ...

  10. MongoDB学习系列(1)--入门介绍

    MongoDB是一款为Web应用程序设计的面向文档结构的数据库系统. MongoDB贡献者是10gen公司.地址:http://www.10gen.com 1.MongoDB主要特性: 1.1文档数据 ...