python同步和异步的区别_Python语言---同步和异步

异步:某个事情需要10秒。而我只需要调用一个函数帮我做,我可以干 其他的事情。(比如调用celery)

同步:某个事情需要10秒完成,我等他完成之后再继续后面的工作。

举例:小明去书店买书

第一种方式(同步):

第二种方式(异步):

阻塞:阻塞调用是指调用结果返回之前,当前线程会被挂起,一直处于等待消息通知,不能够执行其他业务。等待当前函数返回

非阻塞:非阻塞和阻塞的概念相对应,非阻塞调用指在不能立刻得到结果之前也会立刻返回,同时该函数不会阻塞当前线程

阻塞调用和同步调用不同点:

对于同步调用来说,很多时候当前线程可能还是激活的,只是从逻辑上当前函数没有返回而已,此时,这个线程可能也会处理其他的消息。还有一点,在这里先扩展下:

a:如果这个线程在等待当前函数返回时,仍在执行其他消息处理,那这种情况就叫做同步非阻塞;

b:如果这个线程在等待当前函数返回时,没有执行其他消息处理,而是处于挂起等待状态 ,那这种情况就叫做同步阻塞;

所以同步的实现方式会有两种:同步阻塞、同步非阻塞;同理异步也会有两种实现:异步阻塞、异步非阻塞;

非阻塞:非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。虽然表面上看非阻塞的方式可以明显的提高CPU的利用率,但是也带了另外一种后果,就是系统的线程切换增加。增加的CPU执行时间能不能补偿系统的切换成本需要好好评估。

拿上面的例子来说,不论是排队等,还是等待通知,如果在这个过程中,等待者除了等待消息通知之外不能做其它的事情,那么该机制就是阻塞的,表现在程序中,也就是该程序一直阻塞在该函数调用处不能继续往下执行。

相反,有的人喜欢在等待的时候一边刷刷手机或者打打游戏,这样的状态就是非阻塞的,因为他没有阻塞在这个事情上,而是一边做自己的事情一边等待,但是同步非阻塞形式实际上是效率低下的,想象一下你一边打游戏还需要抬头看到底队伍排到你了没有。如果把打游戏和观察排队进行看成是程序的两个操作的话,这个程序需要在这两种不同的行为之间来回的切换,效率可想而知是低下的;而异步非阻塞形式就不存在这样的问题,因为打游戏是你的事,而通知你则是服务人员的事情(触发机制),程序没有在两种不同的操作中来回切换。

-----尚学堂百战程序员笔记(22)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值