概念:
并发:
指一个处理器同时处理多个任务,逻辑上同时发生。
并行:
指多个处理器或者是多核的处理器同时处理多个不同的任务,物理上的同时发生。
打个比方:并发是一个人同时吃三个馒头,而并行是三个人同时吃三个馒头。
区别:
并行:指在同一时刻有多条指令在多个处理器上同时执行。好像两个人各拿一把铁锨在同时挖坑,一个小时以后,每人挖一个大坑。二者无论从微观还是宏观上看都是一起执行的。
并发:指在同一时刻只有一条指令执行,但是多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同步执行,只是把时间分成若干段,使多个进程快速交替执行。这就好像两个人用同一把铁锨,轮流挖坑,一小时后,两个人各挖一个小一点的坑,要是想挖两个大一点的坑,一定用两个小时。
并行可以在多处理器系统中存在,而并发可以在单处理器和多处理器系统中都存在,并发能够在单处理器系统中存在是因为并发是并行的假象,并行要求程序能同时执行多个操作,而并发只是要求程序假装同时执行多个操作(每个小时间段执行一个操作,多个操作快速切换执行)。