http://www.blogjava.net/junglesong/archive/2008/02/22/181356.html
当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间
段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent).
当系统有一个以上CPU时,则线程的操作有可能非并发.当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)
多线程在并发和并行环境中的不同作用
在并发环境时,多线程不可能真正充分利用CPU,节约运行时间,它只是以”挂起->执行->挂起”的方式以很小的时间片分别运行各个线程,给用户以每个线程都在运行的错觉.在这种环境中,多线程程序真正改善的是系统的响应性能和程序的友好性.
在并行环境中, 一个时刻允许多个线程运行,这时多线程程序才真正充分利用了多CPU的处理能力, 节省了整体的运行时间.在这种环境中,多线程程序能体现出它的四大优势:充分利用CPU,节省时间,改善响应和增加程序的友好性.
PS:在多核时代来临后,开发多线程程序的能力更是每个程序员都该具备的.
http://blog.csdn.net/proing/archive/2008/01/28/2069264.aspx
并发和并行的区别就是一个处理器同时处理多个任务和多个处理器或者是多核的处理器同时处理多个不同的任务。
前者是逻辑上的同时发生(simultaneous),而后者是物理上的同时发生.
来个比喻:并发和并行的区别就是一个人同时吃三个馒头和三个人同时吃三个馒头。
分享到:
相关推荐
Windows并发编程指南 Concurrent ...Joe还是并行Parallel LINQ(PLINQ)的开发者,以及在通用语言运行时(CLR)中负责并发功能的程序经理。在加入Microsoft之前,他拥有7年的职业编程经历,包括在EMC工作了四年
详细讲述最新的单指令、多数据流指令和向量化等并行编程技术,介绍现代并行库,讨论如何珠联璧合地使用高级Intel工具与C#,并指导您巧妙使用新引入的轻型协调结构来开发自己的解决方案并解决最棘手的并发编程问题。...
详细讲述最新的单指令、多数据流指令和向量化等并行编程技术,介绍现代并行库,讨论如何珠联璧合地使用高级Intel工具与C#,并指导您巧妙使用新引入的轻型协调结构来开发自己的解决方案并解决最棘手的并发编程问题。...
Joe Duffy是Microsoft公司.NET框架团队...Joe还是并行Parallel LINQ(PLINQ)的开发者,以及在通用语言运行时(CLR)中负责并发功能的程序经理。在加入Microsoft之前,他拥有7年的职业编程经历,包括在EMC工作了四年。
详细讲述最新的单指令、多数据流指令和向量化等并行编程技术,介绍现代并行库,讨论如何珠联璧合地使用高级Intel工具与C#,并指导您巧妙使用新引入的轻型协调结构来开发自己的解决方案并解决最棘手的并发编程问题。...
Joe Duffy是Microsoft公司.NET框架团队中...Joe还是并行Parallel LINQ(PLINQ)的开发者,以及在通用语言运行时(CLR)中负责并发功能的程序经理。在加入Microsoft之前,他拥有7年的职业编程经历,包括在EMC工作了四年
Haskell 在并行并发编程的应用。 非常专业的一本书,对你的Haskell编程技术及理解有很大的帮助
高度并行图形处理器与传统多核处理器的融合正成为现实,要使算法和数据结构在这些新平台上有效地延展,需要考虑几个重要的因素: 1) 算法设计需要利用手头问题固有的并行性; 2) 工作需要有效地分配到可用处理单元;...
通常,所有部分都是顺序执行的,有些部分可以并行执行。 下载 提供了两个版本: [推荐] perl / crun是Perl脚本。 您可能需要通过以下方式安装Perl模块: cpan安装Parallel :: Runner [需要更多测试] go / crun....
12.1 通用、可变、不可变、并发以及并行集合 288 12.1.1 scala.collection包 289 12.1.2 collection.concurrent包 290 12.1.3 collection.convert包 291 12.1.4 collection.generic包 291 12.1.5 ...
指定在Old Generation使用concurrent cmark sweep gc、gc thread和app thread并行(在init-mark和remark时pause app thread)。app pause时间较短,适合交互性强的系统,如web server g: -XX:+...
仅在需要时才实际build软件包并行构建:默认情况下, ultra并发构建软件包工作区依赖关系:工作区依赖关系会自动解决,并用于并行构建执行任何操作:一个命令以递归方式在存储库中运行包脚本, node_modules二进制...
给定下图: A / | \ B C D这意味着,执行顺序将是B , C和D并行,然后是A 可以定义并发量以限制资源使用。用法import { run } from "topological-promise-queue" ;await run ( { concurrency : 10 , edges : [ // a...
25 JAVA8 与元数据.................................................................................................................................25 2.4. 垃圾回收与算法 .................................
25 JAVA8 与元数据.................................................................................................................................25 2.4. 垃圾回收与算法 .................................