网络编程中的阻塞与非阻塞,同步与异步概念的理解
2017-08-11 13:14
441 查看
最近两天闲着没事,就研究了一下socket编程,在网上看别人的domo看了好久,发现被socket通信中的阻塞、非阻塞、同步、异步等概念给绕晕了,虽说这些东西以前都是学过的,但是还是决定重新研究一番。
同步:所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。
就是没有结果就死等!
例如普通B/S模式(同步):提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事异步:
异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。
就是你先干着,干好了再告诉我,我忙我的去。
例如 ajax请求(异步): 请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕阻塞:
阻塞调用是指调用结果返回之前,当前线程会被挂起,CPU暂停对其分配时间片,函数只有在得到结果之后才会返回。
有人也许会把阻塞调用和同步调用等同起来,实际上他是不同的。对于同步调用来说,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已。
就是调用我(函数),我(函数)没有接收完数据或者没有得到结果之前,我不会返回。
例如,我们在socket中调用recv函数,如果缓冲区中没有数据,这个函数就会一直等待,直到有数据才返回。而此时,当前线程还会继续处理各种各样的消息。非阻塞:
非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。
对象的阻塞模式和阻塞函数调用
对象是否处于阻塞模式和函数是不是阻塞调用有很强的相关性,但是并不是一一对应的。阻塞对象上可以有非阻塞的调用方式,我们可以通过一定的API
4000
去轮询状 态,在适当的时候调用阻塞函数,就可以避免阻塞。而对于非阻塞对象,调用特殊的函数也可以进入阻塞调用。函数select就是这样的一个例子。
相关文章推荐
- 网络编程中阻塞与非阻塞、同步与异步、I/O模型的理解
- 网络编程中的异步、同步、阻塞、非阻塞的理解
- 网络编程中的阻塞,非阻塞、同步,异步概念
- 网络编程中阻塞与非阻塞,同步与异步、I/O模型的理解
- 网络编程中阻塞与非阻塞,同步与异步、I/O模型的理解
- 阻塞非阻塞与同步异步区别 发表于 2015-04-18 | 分类于 网络编程 | 在网络编程中,经常会提到同步/异步,阻塞/非阻塞的概念,记得一开始的时候我总是分不清它们之间有什么区别
- 网络编程中阻塞与非阻塞,同步与异步、I/O模型的理解
- 网络编程概念:同步、异步、阻塞和非阻塞
- 【网络编程】(二)同步和异步,阻塞和非阻塞,多路复用技术
- 【Linux网络编程】同步,异步,阻塞,非阻塞
- 网络编程1---阻塞、非阻塞、同步、异步
- 网络编程释疑之:同步,异步,阻塞,非阻塞
- 同步,异步,阻塞,非阻塞概念理解
- 网络编程之同步,阻塞,异步,非阻塞
- 网络编程之同步,阻塞,异步,非阻塞
- 理解 I/O-- 阻塞、非阻塞,同步、异步的概念及其区别
- PHP-Socket-阻塞与非阻塞,同步与异步概念的理解
- 微软BI 之SSIS 系列 - 理解Data Flow Task 中的同步与异步, 阻塞,半阻塞和全阻塞以及Buffer 缓存概念
- 网络编程之同步,阻塞,异步,非阻塞
- 网络编程-阻塞非阻塞同步异步