首页
学习
活动
专区
圈层
工具
发布

关于IO的同步,异步,阻塞,非阻塞

中途正好讨论了网络IO的同步、异步、阻塞、非阻塞的概念,当时讲下来,大家的理解各不相同,各执己见。搜索了网络上的一些文章,观点也各不相同,甚至连wiki也将异步和非阻塞当成一个概念在解释。...虽然网络上充斥了大量关于同步、异步、阻塞、非阻塞的文章,但大都是抄来抄去,没有一个权威的说法。...阻塞和非阻塞 那么阻塞和非阻塞呢?注意到以上五个模型。阻塞IO,非阻塞IO,只是上面的五个模型中的两个。阻塞,非阻塞,是针对单个进程而言的。 当对多路复用IO进行调用时,比如使用poll。...因为poll的底层实现,是去扫描每个文件描述符(fd),而如果要对感兴趣的fd进行扫描,那么只能将每个描述符设置成非阻塞的形式(对于用户进程来讲,设置fd是阻塞还是非阻塞,可以使用系统调用fcntl),...这就要看fd的状态了,如果fd被设置成了非阻塞,那么此时的read就是非阻塞的;如果fd被设置成了阻塞,那么此时的read就是阻塞的。

1.1K40

关于IO的同步,异步,阻塞,非阻塞

中途正好讨论了网络IO的同步、异步、阻塞、非阻塞的概念,当时讲下来,大家的理解各不相同,各执己见。搜索了网络上的一些文章,观点也各不相同,甚至连wiki也将异步和非阻塞当成一个概念在解释。...虽然网络上充斥了大量关于同步、异步、阻塞、非阻塞的文章,但大都是抄来抄去,没有一个权威的说法。...阻塞和非阻塞 那么阻塞和非阻塞呢?注意到以上五个模型。阻塞IO,非阻塞IO,只是上面的五个模型中的两个。阻塞,非阻塞,是针对单个进程而言的。 当对多路复用IO进行调用时,比如使用poll。...因为poll的底层实现,是去扫描每个文件描述符(fd),而如果要对感兴趣的fd进行扫描,那么只能将每个描述符设置成非阻塞的形式(对于用户进程来讲,设置fd是阻塞还是非阻塞,可以使用系统调用fcntl),...这就要看fd的状态了,如果fd被设置成了非阻塞,那么此时的read就是非阻塞的;如果fd被设置成了阻塞,那么此时的read就是阻塞的。

1K100
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    异步,同步,阻塞,非阻塞程序的实现

    终于用透支生命的方法把这一课学完了。感动。以后不这样了。 实现异步非阻塞是一个大命题,这里只从原理出发。我会慢慢修改这篇文章。 本文将从异步sleep的实现入手,来讲解异步非阻塞程序的原理。...什么是异步,同步,阻塞,非阻塞 在写这篇文章前,我对这四个概念是非常模糊的。 同步,异步 异步同步的差异,在于当线程调用函数的时候,线程获取消息的方式....同步: 线程 ----我主动来拿结果----> 函数 异步: 线程 <---你把结果拿给我---- 函数 阻塞,非阻塞 阻塞非阻塞的差异,在于线程调用函数的时候,线程的状态。...线程在同步调用下,也能非阻塞(同步轮循非阻塞函数的状态),在异步下,也能阻塞(调用一个阻塞函数,然后在函数中调用回调,虽然没有什么意义)。 下面,我会慢慢实现一个异步非阻塞的sleep。...场景三:异步非阻塞 实现异步的经典方式是使用回调,实现非阻塞的经典方式是使用线程。 所以,代码就呼之欲出了。

    10.2K10

    真正的 Tornado 异步非阻塞

    博客文章《真正的 Tornado 异步非阻塞》、《使用 JWT 让你的 RESTful API 更安全》等多次入选知名技术社区每日精选。...其中他具备有异步非阻塞能力,能解决他两个框架请求阻塞的问题,在需要并发能力时候就应该使用 Tornado。...但是在实际使用过程中很容易把 Tornado 使用成异步阻塞框架,这样对比其他两大框架没有任何优势而言,本文就如何实现真正的异步非阻塞记录。...当使用 time.sleep(10) 时候会阻塞其他的请求。 ? 这里的异步非阻塞是针对另一请求来说的,本次的请求该是阻塞的仍然是阻塞的。...所以在处理一些小负载的工作,是能起到很好的效果,让 Tornado 异步非阻塞的跑起来。

    4.5K60

    Ajax的异步请求探究

    ajaxxmlhttprequest 在开发中经常使用ajax去请求接口,而ajax不是一项新的技术,基于原生的XmlHttpRequest对象和html css js共同完成 在了解ajax之前先搞清楚什么是...http, 想要了解更多可访问mozllia(霸王龙)的 https://developer.mozilla.org/zh-CN/docs/Web/API/XMLHttpRequest/send# Http...Http http协议是超文本传输协议,该协议详细规定了浏览器和万维网服务器之间互相通信的规则,约定 请求格式 重点是格式与参数 格式 行:{ 1.请求类型:Get, Post, Put, Delete...:application/json 4.user-Agent:chorme 83 } 空行:请求头和请求体的划分行 体:{ 1.username=11&password=10 } 响应报文 行...: utf8 } 空行: 响应头和响应体的划分线 体: 响应报文 AJAX 异步请求使用原生的XmlHttpRequest var http = new XMLHttpRequest

    1.4K20

    总是搞不懂的同步异步,阻塞非阻塞

    摘要:更好的理解同步/异步,阻塞/非阻塞的概念和机制。 一、同步与异步 同步/异步, 它们是消息的通知机制。...异步消息通知机制 类似于 select/poll 之类的多路复用 IO 操作,当所关注的消息被触发时,由消息触发机制通知触发对消息的处理。 异步, 由触发机制来通知处理消息者。...二、阻塞与非阻塞 阻塞/非阻塞, 它们是程序在等待消息(无所谓同步或者异步)时的状态。 1、概念解释 A、阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。...三、易混淆的点 很多人也会把异步和非阻塞混淆,因为异步操作一般都不会在真正的 IO 操作处被阻塞,比如如果用 select 函数,当 select 返回可读时再去 read 一般都不会被阻塞。...四、同步/异步与阻塞/非阻塞的组合分析 同步阻塞形式: 效率是最低的,拿上面的例子来说,就是你专心等待,什么别的事都不做。

    1.1K10

    关于同步异步、阻塞非阻塞IO的摘要

    四种IO模型 Boost application performance using asynchronous I/O把同步阻塞、同步非阻塞、异步阻塞、异步非阻塞的模型讲得很清楚。...处理大量连接的问题 event-driven模型派(异步模型): Dan Kegal's C10K problem 延伸阅读:如何解决C10M问题 The Secret To 10 Million Concurrent...有人对于event-driven模型有一些批判,认为多线程模型(同步阻塞模型)不比事件模型差: Thousands of Threads and Blocking I/O,讲了C10K提到的多线程模型的性能瓶颈在如今的内核里已经不存在了...事件驱动模型解决的是C10K问题,注意C是Connection,解决的是用更少的硬件资源处理更多的连接的问题,它不解决让请求更快速的问题(这是程序员/算法的问题)。...对于事件驱动模型来说也有CPU用满的问题,现实中总会存在一些阻塞操作会造成CPU闲置,这也就是为什么SEDA和Scalable IO in Java都提到了要额外开线程来处理这些阻塞操作。

    1.2K00

    阻塞和非阻塞、同步和异步的讲解

    为了后续的理解,首先搞清楚一个有无数讲解却又令人费解的概念:阻塞和非阻塞、同步和异步。首先需要搞清楚的一件事,就是对于 Linux 系统, I/O 操作不是一步完成的。...了解了这个大前提,我们再来看上述四个概念阻塞和非阻塞首先明确一点:阻塞和非阻塞发生在请求处,关注的是程序在等待调用结果时的状态。...理解上面概念的一个要点是请求的结果是否立即返回,同时需要注意的是,结果立即返回,不代表 I/O 操作完成,阻塞和非阻塞只关注请求是否立即获得结果。...同步和异步是指访问数据的机制,同步一般指主动请求并等待 I/O 操作完毕的方式,当数据就绪后在读写的时候必须等待,异步则指主动请求数据后便可以继续处理其它任务,随后等待 I/O,操作完毕的通知,这可以使进程在数据读写时也不阻塞...socket的 I/O 操作是阻塞的- 非阻塞 I/O (non-blocking I/O ) - 当 I/O 请求时,如果数据没有准备好,则返回一个错误,然后进程可以干其他事,隔段时间,

    44610

    怎样理解阻塞非阻塞与同步异步的区别?

    书中向我们提及了5种类UNIX下可用的I/O模型: 阻塞式I/O; 非阻塞式I/O; I/O复用(select,poll,epoll…); 信号驱动式I/O(SIGIO); 异步...非阻塞式I/O: 以下这句话很重要:进程把一个套接字设置成非阻塞是在通知内核,当所请求的I/O操作非得把本进程投入睡眠才能完成时,不要把进程投入睡眠,而是返回一个错误。...看看非阻塞的套接字的recvfrom操作如何进行 可以看出recvfrom总是立即返回。...相反,异步I/O模型在这两个阶段都要处理。 再看POSIX对这两个术语的定义: 同步I/O操作:导致请求进程阻塞,直到I/O操作完成; 异步I/O操作:不导致请求进程阻塞。...好,下面我用我的语言来总结一下阻塞,非阻塞,同步,异步 阻塞,非阻塞:进程/线程要访问的数据是否就绪,进程/线程是否需要等待; 同步,异步:访问数据的方式,同步需要主动读写数据,在读写数据的过程中还是会阻塞

    60820

    对于同步、异步、阻塞、非阻塞的几点浅薄理

    ; 异步消息通知机制:类似于select/poll 之类的多路复用IO 操作,                   当所关注的消息被触发时,由消息触发机制通知触发对消息的处理.                   ...二、阻塞与非阻塞 阻塞/非阻塞, 它们是程序在等待消息(无所谓同步或者异步)时的状态. 1. 概念解释     阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起。...四、同步/异步与阻塞/非阻塞的组合分析 _______阻塞____________________非阻塞_____ 同步 | 同步阻塞              同步非阻塞 异步 | 异步阻塞              ...异步非阻塞 同步阻塞形式:   效率是最低的,   拿上面的例子来说,就是你专心排队,什么别的事都不做。   ...,效率可想而知是低下的;   很多人会写阻塞的read/write 操作,   但是别忘了可以对fd 设置O_NONBLOCK 标志位,这样就可以将同步操作变成非阻塞的了; 异步非阻塞形式:   效率更高

    77620

    非阻塞 IO:异步编程提升 Python 应用速度

    本文将探讨非阻塞 I/O 和异步编程如何提升 Python 应用的速度,并提供具体的实现代码过程,包括如何在代码中添加代理信息。...非阻塞 I/O 的重要性在传统的同步编程模型中,I/O 操作(如读取文件、网络请求等)会阻塞当前线程,直到操作完成。这导致应用程序在等待 I/O 操作时无法执行其他任务,从而降低了效率和响应速度。...实现非阻塞 I/O 的代码过程以下是一个使用 asyncio 库和 aiohttp 实现非阻塞 I/O 的示例代码,该代码模拟了一个简单的异步 HTTP 客户端,用于非阻塞地发送 HTTP 请求并接收响应...更好的用户体验:对于 Web 应用和用户界面,异步编程可以避免界面冻结,因为它们可以在不阻塞主线程的情况下进行网络请求或其他 I/O 操作。...结论非阻塞 I/O 和异步编程是提高 Python 应用速度的有效手段。通过使用 asyncio 库和 aiohttp 等异步库,开发者可以构建高性能、高响应速度的应用程序。

    48500

    阻塞式非阻塞式与同步异步的区别

    阻塞式IO/非阻塞IO 阻塞式IO(blocking-IO) 默认情况下,所有的套接字socket连接都是阻塞式的,在和操作系统交互的过程之中。...首先进行IO数据交换的时候是由两个进程交互的,一个是用户的application进程另外一个是操作系统的内核进程,阻塞强调的是在用户进程发起数据调用请求到操作系统kernal之后,需要等待操作系统(准备数据...非阻塞式IO(No blocking-IO) 同样的对于客户端的一个read操作,当客户端发起read request的时候,如果kernal这时候还没有将待拷贝的数据准备好,那么则会直接返回系统错误的状态...只有再次向kernal发起同样的请求这时候(这个过程因为每次请求会立即得到返回,所以对于客户端来说并不是非阻塞的或者说锁定的,客户端可以在这个过程中做其他事情),看看kernal有没有准备好,若是准备好了那么则将数据从系统空间拷贝到用户内存当中去...可以看出来同步和异步的区别就是在于,客户端请求完成之后到kernal的IO operation完成这个过程中客户端是不是阻塞或者锁定状态,如果是则是同步,否则则是异步。 比较:

    35810

    【SpringBoot WEB 系列】AsyncRestTemplate 之异步非阻塞网络请求介绍篇

    [logo.jpg] 【SpringBoot WEB 系列】AsyncRestTemplate 之异步非阻塞网络请求介绍篇 AsyncRestTemplate 发起异步网络请求,由 Spring4.0...虽然官方已经不推荐使用AsyncRestTemplate,但是如果你的 web 项目,并不想引入 react 相关的包,使用AsyncRestTemplate来实现异步网络请求也不失为一个选择,本文将主要介绍它的基本使用姿势...ListenerableFuture的最大特点在于它可以绑定执行完成的监听器,就不需要通过 get 来阻塞获取结果了,一个简单的使用姿势如下, 分别演示正常返回,异常返回的回调 case(两者都不会阻塞主线程的执行哦...文案会优先输出,并不会被阻塞;然后就是返回结果之后的回调,因为第一个 case 访问的 rest 服务有个 sleep,所以输出也会有一个明显的滞后 [00.gif] 2....Guava 方式的异步请求 除了上面说到的 AsyncRestTemplate 来实现异步访问,我们也可以借助 Gauva 配合RestTemplate来实现类似的效果,下面作为扩展知识点,给出一个等效的使用说明

    6.6K31

    Netty系列(六):阻塞非阻塞、同步异步的区别

    Blocking/Nonblocking、Synchronous/Asynchronous 阻塞( Blocking ) /非阻塞( Nonblocking) 同步(Synchronous)/异步( Asynchronous...消息的传递有可能是阻塞的或非阻塞的 —— 也被称为同步或异步的: 阻塞式发送(blocking send). 发送方进程会被一直阻塞, 直到消息被接受方进程收到。...上述不同类型的发送方式和不同类型的接收方式,可以自由组合。 从进程通讯上来看,阻塞或非阻塞 以及 同步或异步是近义词。...同步:即阻塞发送,发送方A调用 send() 方法与接收方B通信,由于是同步的,那么在发送方A进程所对应的系统内核空间中,内核缓冲区的数据没发送出去之前,发送方A进程都是一直等待的 异步:即非阻塞发送,...这里阻塞或非阻塞描述的是进程是否变为等待状态,变为等待状态则说明发生了阻塞。

    63610

    异步编程 - 11 Spring WebFlux的异步非阻塞处理

    应用程序需要更高级别和更丰富的功能API来组成异步逻辑——类似于Java 8 Stream API,但其不仅适用于集合。...Spring Boot之所以默认用Netty作为服务器,是因为Netty在异步、非阻塞领域中使用得比较广泛,并允许客户端和服务器共享资源(比如共享NioEventLoopGroup)。...在Spring WebFlux(以及一般的非阻塞服务器,例如Netty)中,假设应用程序不会阻塞,因此非阻塞服务器使用小的固定大小的线程池(事件循环IO工作线程)来处理请求。...相反以非阻塞的方式来执行,需要做更多的额外工作,并且可能会增加处理所需的时间。 反应式和非阻塞的关键好处是能够使用少量固定数量的线程和更少的内存实现系统可伸缩性。...小结 Spring 5.0引入的新的异步非阻塞的WebFlux技术栈,其与Servlet技术栈是并行存在的。

    3.6K30

    异步编程 - 10 Web Servlet的异步非阻塞处理

    OverView 我们这里主要讨论Servlet3.0规范前的同步处理模型和缺点,Servlet3.0规范提供的异步处理能力与Servlet3.1规范提供的非阻塞IO能力,以及Spring MVC中提供的异步处理能力...---- Servlet 3.1提供的非阻塞IO能力 虽然Servlet 3.0规范让Servlet的执行变为了异步,但是其IO还是阻塞式的。...在Servlet3.1规范中提供了非阻塞IO处理方式:Web容器中的非阻塞请求处理有助于增加Web容器可同时处理请求的连接数量。...非阻塞IO对在Servlet和Filter中的异步请求处理有效,否则,当调用ServletInputStream.setReadListener或Servlet OutputStream.setWriteListener...【Servlet非阻塞IO处理】 如上图所示,Servlet容器接收请求后会从容器线程池获取一个线程来执行具体Servlet的Service方法,Service方法内调用StartAsync开启异步处理

    1.2K20

    深入讨论阻塞与非阻塞、同步与异步的区别

    阻塞:做某件事情,直到完成,除非超时 非阻塞:尝试做,如果不能做,就不做(直接返回),如果能做,就做。 前两者和后两者不容易区分,不过前两者更多的有涉及到多线程交互(消息)的场景。...(同步阻塞) 小李感觉这样太费时间。 2、小李把水壶放到炉子上,去客厅看电视,时不时去厨房看看水开没有。(同步非阻塞) 小李还是觉得自己这样太累,于是买了把会响笛的那种水壶。水开之后,能发出声音。...(异步阻塞) 觉得这样傻等意义不大 5、小李把响水壶放到炉子上,去客厅看电视,水壶响之前不再去看它了,响了再去拿壶。(异步非阻塞) 这样真好。...(当然如果你通过setsockopt设置了读写超时,超时时间到了还是会返回-1和EAGAIN,不再睡觉等待) 非阻塞就是recv/read的时候,要是接收缓冲区有数据我就读完,没有数据我直接带着返回的-...这样当配合非阻塞的socket使用时,只有当系统通知我哪个描述符可读了,我才去执行read操作,可以保证每次read都能读到有效数据而不做纯返回-1和EAGAIN的无用功。写操作类似。

    47420

    那些年让人迷惑的同步、异步、阻塞、非阻塞

    本文为转载文章,原文链接:https://www.jianshu.com/p/3d603166f54d 在IT圈混饭吃,不管你用什么编程语言、从事前端还是后端,阻塞、非阻塞、异步、同步这些概念,...我们可以看到,小进发出接收输入的请求给内核开始,就处于阻塞状态,直到内核将数据复制到小进的用户空间,小进才解除阻塞。...一个非阻塞丢给小进,小进立马复活 小进:哇!数据来了,啥也不说,干活! 我们看到,所谓的非阻塞I/O,其实在内核将数据从内核空间复制到小进的用户空间时,小进还是被阻塞的。...第二、第三种方案中,只在内核将数据从内核空间复制到小进的用户空间时,小进才被阻塞。 我们现在说的异步I/O,目的就是让小进绝对不被阻塞。...7、无总结,不进步 上面,我们从完成输入时,进程与内核的交互方式的角度分析了不同的I/O解决方案,在这个过程中,解释清楚了阻塞、非阻塞、同步、异步的概念。

    42020
    领券