并行与并发
生活例子:
你吃饭吃到一半,电话来了,你一直到吃完了以后才去接,这就说明你不支持并发也不支持并行。
你吃饭吃到一半,电话来了,你停了下来接了电话,接完后继续吃饭,这说明你支持并发。
你吃饭吃到一半,电话来了,你一边打电话一边吃饭,这说明你支持并行。
并行的关键是你有同时处理多个任务的能力。
并发的关键是你有处理多个任务的能力,不一定要同时。
Parallel(并行)
同一时刻执行多个任务,多个执行者同时执行多个任务,多进程就是并行执行的。
场景:
CPU运算量大的程序程序,使用多进程,并行处理会更好。
Concurrency(并发)
在同一时间间隔内多个任务都在运行,但是并不会在同一时刻同时运行,存在交替执行的情况,多线程就是并发执行的。
场景:
程序需要执行较多的读写、请求和回复任务的需要大量的IO操作,IO密集型操作使用多线程,并发处理更好。
阻塞与非阻塞,同步与异步
第一个生活例子:
假设你在食堂打饭,打饭的人很多,阻塞了,需要排队,有的人忘记带手机了,而且是一个人来的,没有朋友,那么他就只能干等着,啥事也干不了。阻塞的时候做不了其他事情,只能干等,这种称之为同步处理。
而你带了手机,你在排队的时候,还能看手机,玩玩游戏,然后师傅说到你打饭了,你就结束玩手机,开始打饭。遇到阻塞时,就先处理别的事情,这种称之为异步处理。
第二个生活例子:
比如你打电话去书店问有没有某某书。
同步的做法是,老板让你等一下,他找找。此时整个通信过程会在一次通话中完成。
异步的做法是,老板说他找一下,迟点再打电话给你。此时通信过程分成两次通话完成。
阻塞的做法是,老板让你等一下,你就一直拿着电话在等老板的回复,等待期间什么事都不干。
非阻塞的做法是,先挂掉电话,等老板来电回复,才回来继续这个通话。
结合一下:
同步阻塞就是,你一直在那里等,老板也不挂掉电话,直到他找到或者没找到再回复你。
异步阻塞就是,老板说找到了再回电给你,但你仍停在那里,什么都不干只等电话。
同步非阻塞就是,老板没挂电话,但是你先去干别的事情了,不在电话前等着他。
异步非阻塞就是,挂掉电话,你先去干别的事情,老板来电回复,就继续通话。
协程就是异步的。