同步/异步,阻塞/非阻塞
来源:互联网 发布:clean my mac好用吗 编辑:程序博客网 时间:2024/05/17 01:39
整体来说,同步是两个对象之间的关系,而阻塞是一个对象的状态。其次,同步就是两种东西通过一种机制实现步调一致,异步是两种东西不必步调一致。
一、同步调用与异步调用:
在用在调用场景中,无非是对调用结果的不同处理。
我理解同步调用就是调用一但返回,就能知道结果,而异步是返回时不一定知道结果,还得通过其他机制来获知结果,如:
这里的异步调用:
调用过程会立即返回不阻塞,但是有时候却拿不到结果(如selector.select()不管是否有注册的事件发生都会立即返回数目,除非设置了超时参数);有时候是收到消息通知后由回调函数获取调用的结果,而等待消息通知的过程中会被阻塞住(wait/notify阻塞或死循环阻塞,前者不占用CPU时间,后者会占用CPU时间),比如Java NIO的Reactor机制,虽然selector.select过程不阻塞立即返回,但是却要放在一个whiel(ture)死循环中一直等待消息通知,直到有注册的事件发生再调用回调函数进行处理,处理过程还是同步的。宁外一种AIO,真正的异步IO,等待通知过程由系统中断机制实现,等待过程也不阻塞。
所以:异步调用的过程是不阻塞的,但是等待消息通知过程可能会阻塞住(专门有人帮你等消息,然后通知你,这个notifier专门负责帮很多人等消息,然后通知他们,这就是社会分工,这样用notifier一个人的时间,解放了很多人的时间,从而提高整体的工作效率),消息处理过程还是同步的,该读写多久就是多久,偷不了懒的。异步调用会立即返回,返回的结果是消息通知,真正的结果(消息)一般是在回调函数中获取。
为什么需要异步调用:
异步调用可以使用多线程来充分利用多核机器的处理能力,可在硬件环境不改变的情况下适当的增加软件系统的吞吐量。
二、同步线程与异步线程:
三、同步通信与异步通信:
这里的同步和异步是指:发送方和接收方是否协调步调一致!
阻塞可以是实现同步的一种手段!例如两个东西需要同步,一旦出现不同步情况,我就阻塞快的一方,使双方达到同步。
REF-1:http://blog.chinaunix.net/uid-21411227-id-1826898.html
REF-2:http://blog.chinaunix.net/uid-26000296-id-3754118.html
REF-3:http://www.cnblogs.com/albert1017/p/3914149.html
一、同步调用与异步调用:
在用在调用场景中,无非是对调用结果的不同处理。
我理解同步调用就是调用一但返回,就能知道结果,而异步是返回时不一定知道结果,还得通过其他机制来获知结果,如:
- 状态
- 通知
- 回调函数
- 调用可能一直阻塞(阻塞在消息处理过程,等待消息处理完成)住,直到返回正确的结果。
- 调用不会阻塞而是立即返回,但是立即返回的可能是失败的结果。
这里的异步调用:
调用过程会立即返回不阻塞,但是有时候却拿不到结果(如selector.select()不管是否有注册的事件发生都会立即返回数目,除非设置了超时参数);有时候是收到消息通知后由回调函数获取调用的结果,而等待消息通知的过程中会被阻塞住(wait/notify阻塞或死循环阻塞,前者不占用CPU时间,后者会占用CPU时间),比如Java NIO的Reactor机制,虽然selector.select过程不阻塞立即返回,但是却要放在一个whiel(ture)死循环中一直等待消息通知,直到有注册的事件发生再调用回调函数进行处理,处理过程还是同步的。宁外一种AIO,真正的异步IO,等待通知过程由系统中断机制实现,等待过程也不阻塞。
所以:异步调用的过程是不阻塞的,但是等待消息通知过程可能会阻塞住(专门有人帮你等消息,然后通知你,这个notifier专门负责帮很多人等消息,然后通知他们,这就是社会分工,这样用notifier一个人的时间,解放了很多人的时间,从而提高整体的工作效率),消息处理过程还是同步的,该读写多久就是多久,偷不了懒的。异步调用会立即返回,返回的结果是消息通知,真正的结果(消息)一般是在回调函数中获取。
为什么需要异步调用:
异步调用可以使用多线程来充分利用多核机器的处理能力,可在硬件环境不改变的情况下适当的增加软件系统的吞吐量。
二、同步线程与异步线程:
- 同步线程:即两个线程步调要一致,要相互协商。两个线程的运行进度各不相同,怎么才能步调一致呢?我们直观的理解就是,快的等慢的呗!快的阻塞一下等到慢的步调一致即可。
- 异步线程:步调不用一致,各自按各自的步调运行,不受另一个线程的影响。
三、同步通信与异步通信:
这里的同步和异步是指:发送方和接收方是否协调步调一致!
- 同步通信是指:发送方和接收方通过一定机制,实现收发步调协调。如:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式
- 异步通信是指:发送方的发送不管接收方的接收状态,如:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式。
阻塞可以是实现同步的一种手段!例如两个东西需要同步,一旦出现不同步情况,我就阻塞快的一方,使双方达到同步。
REF-1:http://blog.chinaunix.net/uid-21411227-id-1826898.html
REF-2:http://blog.chinaunix.net/uid-26000296-id-3754118.html
REF-3:http://www.cnblogs.com/albert1017/p/3914149.html
0 0
- 同步阻塞, 同步非阻塞,异步阻塞,异步非阻塞
- 同步、异步、阻塞、非阻塞
- 同步,异步,阻塞,非阻塞
- 同步 异步 阻塞 非阻塞
- 同步,异步,阻塞,非阻塞
- 阻塞,非阻塞,异步,同步
- 同步 异步 阻塞 非阻塞
- 同步 异步 阻塞 非阻塞
- 同步 异步 阻塞 非阻塞
- 同步异步 阻塞非阻塞
- 同步 异步 阻塞 非阻塞
- 同步、异步,阻塞、非阻塞
- 阻塞 非阻塞 同步 /异步
- 同步/异步 阻塞/非阻塞
- 同步 异步 阻塞 非阻塞
- 同步异步 阻塞非阻塞
- 同步 异步 阻塞 非阻塞
- 同步/异步 阻塞/非阻塞 .
- 一些可用的Google Ip
- NotificationCenter的基本使用
- 跨站实现HTTP会话劫持
- mysql id按指定的格式自增
- 指针数组和数组指针
- 同步/异步,阻塞/非阻塞
- Android Selector 与 Shape 基本用法
- 第9周项目6穷举法解决组合问题之警察抓小偷
- ARM linux kernel启动流程 head.S(一)
- Cocos2d-X3.0 刨根问底(三)----- Director类源码分析
- 查看CentOS版本及内核
- 配合静态仓库进行二进制数据存取
- 第9周项目6穷举法解决问题三色球问题
- 解决 MyEclipse出现the user operation is waiting的问题