并发与并行的区别

概念:

并发:

指一个处理器同时处理多个任务,逻辑上同时发生。

并行:

指多个处理器或者是多核的处理器同时处理多个不同的任务,物理上的同时发生。

打个比方:并发是一个人同时吃三个馒头,而并行是三个人同时吃三个馒头。

区别:

并行:指在同一时刻有多条指令在多个处理器上同时执行。好像两个人各拿一把铁锨在同时挖坑,一个小时以后,每人挖一个大坑。二者无论从微观还是宏观上看都是一起执行的。

并发:指在同一时刻只有一条指令执行,但是多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同步执行,只是把时间分成若干段,使多个进程快速交替执行。这就好像两个人用同一把铁锨,轮流挖坑,一小时后,两个人各挖一个小一点的坑,要是想挖两个大一点的坑,一定用两个小时。

 

 并行可以在多处理器系统中存在,而并发可以在单处理器和多处理器系统中都存在,并发能够在单处理器系统中存在是因为并发是并行的假象,并行要求程序能同时执行多个操作,而并发只是要求程序假装同时执行多个操作(每个小时间段执行一个操作,多个操作快速切换执行)。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值