什么是并发
我们先来举一个很常见的例子:
如果你现在很渴想泡壶茶喝,但你发现家里没有茶叶,水杯都放了很久没洗,并且没有开水,这时候你会怎么做呢?
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只执行一个任务,他们之间互不影响。
如果你觉得这个例子还是难以理解,可以看看国外大咖提出的买咖啡的例子:
对于并发来说,只有一个咖啡机,所以两个队列需要交替使用一台咖啡机。
对于并行来说,有两个咖啡机,两个队列各买各的,互不影响。
相信你已经看出来了,对于并行没有什么可研究的,只需要电脑硬件支持就可以了,下面我们就来详细谈谈并发。