并发(Concurrent)与并行(Parallel)的区别
2010-11-02 15:44
337 查看
并发和并行的区别就是一个处理器同时处理多个任务和多个处理器或者是多核的处理器同时处理多个不同的任务。
前者是逻辑上的同时发生(simultaneous),而后者是物理上的同时发生.
来个比喻:并发和并行的区别就是一个人同时吃三个馒头和三个人同时吃三个馒头。
当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent).
当系统有一个以上CPU时,则线程的操作有可能非并发.当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)
以上分别转自:
http://blog.csdn.net/proing/archive/2008/01/28/2069264.aspx
http://www.blogjava.net/junglesong/archive/2008/02/22/181356.html
前者是逻辑上的同时发生(simultaneous),而后者是物理上的同时发生.
来个比喻:并发和并行的区别就是一个人同时吃三个馒头和三个人同时吃三个馒头。
当有多个线程在操作时,如果系统只有一个CPU,则它根本不可能真正同时进行一个以上的线程,它只能把CPU运行时间划分成若干个时间段,再将时间段分配给各个线程执行,在一个时间段的线程代码运行时,其它线程处于挂起状态.这种方式我们称之为并发(Concurrent).
当系统有一个以上CPU时,则线程的操作有可能非并发.当一个CPU执行一个线程时,另一个CPU可以执行另一个线程,两个线程互不抢占CPU资源,可以同时进行,这种方式我们称之为并行(Parallel)
以上分别转自:
http://blog.csdn.net/proing/archive/2008/01/28/2069264.aspx
http://www.blogjava.net/junglesong/archive/2008/02/22/181356.html
相关文章推荐
- 并发(Concurrent)与并行(Parallel)的区别
- 并发Concurrent与并行Parallel的区别
- 并发 concurrent 与并行 parallel 的区别
- 并发(Concurrent) 与并行(Parallel) 的区别
- 操作系统中并发(concurrent)与并行(Parallel )的区别与联系
- 并行parallel和并发concurrent的区别
- 并发(Concurrent)与并行(Parallel)的区别
- Java并发编程四:并发(Concurrent)与并行(Parallel)区别(二)
- 并发(Concurrent)与并行(Parallel)的区别
- Java并发编程三:并发(Concurrent)与并行(Parallel)的区别(一)
- 并发Concurrent与并行Parallel的区别
- 并发(Concurrent)与并行(Parallel)的区别
- 串行(Sequential)、并发(Concurrent)、并行(parallel)与分布式(distributed)
- 并发(Concurrent)与并行(Parallel)
- 并发与并行的区别 The differences between Concurrency and Parallel
- 并发(Concurrent)与并行(Parallel)
- 并发(Concurrent)与并行(Parallel)
- 串行(Sequential)、并发(Concurrent)、并行(parallel)与分布式(distributed)
- 并行(parallel)和并发(concurrency)的区别和联系
- 并发和并行的区别