并发(Concurrent)与并行(Parallel)的区别
2015-10-06 11:53
387 查看
并发和并行的区别就是一个处理器同时处理多个任务和多个处理器或者是多核的处理器同时处理多个不同的任务。
前者是逻辑上的同时发生(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
相关文章推荐
- 公共语言运行库(CLR)
- MYSQL 删除重复记录,只保留最大ID
- Hibernate缓存机制以及一级缓存和二级缓存的作用
- Servlet的生命周期
- 日经春秋 20151006
- HTML-Html开发之Viewport的使用
- 无法找到元素 'util:list' 的声明
- hdu 1856 more is better
- 天声人語 20151006 空爆された病院
- POJ 题目3254 Corn Fields(状压DP)
- 栈的作用
- HASHTABLE, HashMap,TreeMap区别
- python3 操作Excel文件
- vector中的剥离现象
- 我写过的软件之OneWorld-大世界2
- String,StringBuffer, StringBuilder 的区别
- [leetcode279] perfect squares
- 登陆
- Delphi XE7 学习笔记 StopWatch类
- UICollectionView 以及 AWCollectionViewDialLayout