01 并发概述

什么是并发

我们先来举一个很常见的例子:

如果你现在很渴想泡壶茶喝,但你发现家里没有茶叶,水杯都放了很久没洗,并且没有开水,这时候你会怎么做呢?

Method A:

先出去买茶叶,然后回来把水杯洗了,再然后烧水,最后就可以开心的泡茶了。

Method B:

先把水烧上,在烧水的间隙出去买茶叶,回来后洗茶杯,等水烧好就可以开心的泡茶了。

在这里如果我们假设:买茶叶需要3分钟,洗水杯需要4分钟,烧水需要15分钟。我们可以看到:

Method A总共需要花费:3+4+15=22分钟

Method B总共需要花费:15分钟

OK 到这里我想你大概明白我在讲什么了。很明显,Method A中我们在面对买茶叶、洗茶杯、烧水这三个任务的时候,我们每次只执行一个任务,当前任务没有结束的情况下,我们不执行下一个任务,我们把这种方式叫做串行

但是烧水这个任务有很长的等待时间,在这个等待时间里我们完全可以执行其它任务,所有我们有了method B这种方案。在当前任务没有执行完的情况下,我们可以执行下一个任务,达到多个任务同时执行的效果,我们把这种方式叫做并发

通过上面的例子我们可以看到并发在多任务下的一个优点:在当前任务陷入阻塞或等待的情况下,有效利用当前计算资源。

并发和并行

并发和并行都是处理多任务的方式,从宏观角度来看,并发和并行的执行效果没有任何区别,但是从微观角度来讲,两者差距很大。

也许此时此刻你正坐在电脑前听着音乐看这篇博客,同时你的360也在后台为你运行电脑的健康监测。我们定义任务A为浏览网页博客,任务B为听音乐,任务C为后台检测电脑状态。

如果你的电脑是单核的,那么从微观角度来看,他的任务执行是这个样子的。


如果你的电脑是多核的,那么从微观角度来看,他们的任务执行顺序是这个样子的。


如果你的电脑是单核的,那么在一个CPU上A、B、C三个任务需要轮流执行,在具体的某一个时刻只有一个任务在执行。只不过因为CPU的切换速度很快,所以你看到的效果就是他们是同时运行的。但对于多核的电脑来说,ABC三个任务完全可以在不同的CPU上来执行,每个CPU只执行一个任务,他们之间互不影响。

如果你觉得这个例子还是难以理解,可以看看国外大咖提出的买咖啡的例子:


对于并发来说,只有一个咖啡机,所以两个队列需要交替使用一台咖啡机。

对于并行来说,有两个咖啡机,两个队列各买各的,互不影响。

相信你已经看出来了,对于并行没有什么可研究的,只需要电脑硬件支持就可以了,下面我们就来详细谈谈并发。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java Concurrency 并发模型 并发系统可以使用不同的并发模型来实现。 并发模型指定系统中的线程如何协...
    熬夜的猫头鹰阅读 269评论 0 1
  • 后期整理字体以及排版问题,修订不适合的翻译 “A wealth of information. Smart, ye...
    iamzzz阅读 761评论 0 0
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,142评论 1 32
  • 1.介绍下内存的几大区域? 2.你是如何组件化解耦的? 3.runtime如何通过selector找到对应的IMP...
    小孩仔阅读 1,725评论 0 21
  • 记得老罗曾经在如何成为高手中说过,套路与知识罐头是其中一个非常重要的要素。打个比方比如你在记性。点评某个事物的时候...
    明月清风舟阅读 440评论 0 0