A-A+

关于并发与并行的区别

2014年02月26日 编程开发 评论 2 条 阅读 1,810 次
如果您有代购或者代维服务器、PHP网站建设、程序代码修改、系统开发等需求,可以联系我购买付费服务。QQ 379880222

所有的并发处理都有排队等候,唤醒,执行至少三个这样的步骤.所以并发肯定是宏观概念,在微观上他们都是序列被处理的,只不过资源不会在某一个上被阻塞 (一般是通过时间片轮转),所以在宏观上看多个几乎同时到达的请求同时在被处理。如果是同一时刻到达的请求也会根据优先级的不同,而先后进入队列排队等候执行。

并发与并行是两个既相似而又不相同的概念:并发性,又称共行性,是指能处理多个同时性活动的能力;并行是指同时发生的两个并发事件,具有并发的含义,而并发则不一定并行,也亦是说并发事件之间不一定要同一时刻发生。

并发和并行的区别仅仅在发生时刻的不同吗?

举个例子理解一下,如:

假设有A、B 两个事件

并行:

如果A和B都在15:30同时发生,A 的运行时间为 5 分钟,B 的运行时间为 8 分钟

在前5分钟是并行,也包括并发,因为他们都是在同一时刻发生的

并发:

如果A在15:30发生,运行3分钟后,B事件发生,在以后的5分钟时间里,A和B 是并发的

并发,是在同一个cpu上同时(不是真正的同时,而是看来是同时,因为cpu要在多个程序间切换)运行多个程序。

并行,是每个cpu运行一个程序。

打个比方,并发,就像一个人(cpu)喂2个孩子(程序),轮换着每人喂一口,表面上两个孩子都在吃饭。

并行,就是2个人喂2个孩子,两个孩子也同时在吃饭。

并发就是一个处理器同时处理多个任务(逻辑上的同时发生)。

并行就是多个处理器或者是多核的处理器同时处理多个不同的任务(物理上的同时发生)。

来个比喻:并发和并行的区别就是一个人同时吃三个馒头和三个人同时吃三个馒头。

标签:

2 条留言  访客:1 条  博主:1 条

  1. avatar 周樹全

    不能叫吃饭吧,应该叫喝奶,:-D

    • avatar 恋香缘

      应该叫吃奶。

给我留言