并行与并发,同步与异步

并行与并发

生活例子:

你吃饭吃到一半,电话来了,你一直到吃完了以后才去接,这就说明你不支持并发也不支持并行。

你吃饭吃到一半,电话来了,你停了下来接了电话,接完后继续吃饭,这说明你支持并发。

你吃饭吃到一半,电话来了,你一边打电话一边吃饭,这说明你支持并行。

并行的关键是你有同时处理多个任务的能力。 

并发的关键是你有处理多个任务的能力,不一定要同时。

Parallel(并行)

同一时刻执行多个任务,多个执行者同时执行多个任务,多进程就是并行执行的。

场景:

CPU运算量大的程序程序,使用多进程,并行处理会更好。

Concurrency(并发)

在同一时间间隔内多个任务都在运行,但是并不会在同一时刻同时运行,存在交替执行的情况,多线程就是并发执行的。

场景:

程序需要执行较多的读写、请求和回复任务的需要大量的IO操作,IO密集型操作使用多线程,并发处理更好。

阻塞与非阻塞,同步与异步

第一个生活例子:

假设你在食堂打饭,打饭的人很多,阻塞了,需要排队,有的人忘记带手机了,而且是一个人来的,没有朋友,那么他就只能干等着,啥事也干不了。阻塞的时候做不了其他事情,只能干等,这种称之为同步处理。

而你带了手机,你在排队的时候,还能看手机,玩玩游戏,然后师傅说到你打饭了,你就结束玩手机,开始打饭。遇到阻塞时,就先处理别的事情,这种称之为异步处理。

第二个生活例子:

比如你打电话去书店问有没有某某书。

同步的做法是,老板让你等一下,他找找。此时整个通信过程会在一次通话中完成。

异步的做法是,老板说他找一下,迟点再打电话给你。此时通信过程分成两次通话完成。

阻塞的做法是,老板让你等一下,你就一直拿着电话在等老板的回复,等待期间什么事都不干。

非阻塞的做法是,先挂掉电话,等老板来电回复,才回来继续这个通话。

结合一下:

同步阻塞就是,你一直在那里等,老板也不挂掉电话,直到他找到或者没找到再回复你。

异步阻塞就是,老板说找到了再回电给你,但你仍停在那里,什么都不干只等电话。

同步非阻塞就是,老板没挂电话,但是你先去干别的事情了,不在电话前等着他。

异步非阻塞就是,挂掉电话,你先去干别的事情,老板来电回复,就继续通话。

协程就是异步的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值