并发和并行


Erlang 之父 Joe Armstrong 用一张5岁小孩都能看懂的图解释了并发与并行的区别



并发是两个队列交替使用一台咖啡机,并行是两个队列同时使用两台咖啡机,如果串行,一个队列

使用一台咖啡机,后面的人也只能死等着他回来才能去接咖啡,这效率无疑是最低的。

知乎上有评论里说,并发是不是一个线程,并行是多个线程?
答:并发和并行都可以是很多个线程,就看这些线程能不能同时被(多个)cpu执行,如果可以就
说明是并行,而并发是多个线程被(一个)cpu 轮流切换着执行。


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

猜你喜欢

转载自blog.csdn.net/qq_39839136/article/details/80899774