首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Netty】「NIO」(二)阻塞模式与非阻塞模式

前言 本篇博文是《从0到1学习 Netty》中 NIO 系列的第二篇博文,主要内容是通过 NIO 来理解阻塞模式与非阻塞模式,往期系列文章请访问博主的 Netty 专栏,博文中的所有代码全部收集在博主的...GitHub 仓库中; 介绍 阻塞模式 在 Java NIO 中,阻塞模式是一种传统的 I/O 处理方式,当我们试图从通道进行读取或向通道写入数据时,这种模式会使线程阻塞直到操作完成。...因此,对于高并发应用程序,通常使用非阻塞和异步 I/O 模式来提高性能。 非阻塞模式 在 Java NIO 中,非阻塞模式是一种非常重要的概念。...选择使用阻塞模式还是非阻塞模式,取决于具体的应用场景和性能需求:阻塞模式简单直观,适用于连接数较小且对响应时间要求不高的场景;而非阻塞模式则适用于高并发、大规模连接的情况下,能够更好地利用系统资源和提供更高的性能...以上就是 阻塞模式与非阻塞模式 的所有内容了,希望本篇博文对大家有所帮助!

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

    Linux编程(阻塞和非阻塞IO)

    Linux设备驱动中的阻塞和非阻塞I/0,简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的支持用户空间对设备的这两种访问方式。...非阻塞应用程序通常使用select系统调用查询是否可以对设备进行无阻塞的访问最终会引发设备驱动中 poll 函数执行。...=1); //串口上没有输入则返回,所以循环读取 printf("%c/n",buf); 阻塞操作常常用等待队列来实现,而非阻塞操作用轮询的方式来实现。...非阻塞I/O的操作在应用层通常会用到select()和poll()系统调用查询是否可对设备进行无阻塞访问。select()和poll()系统调用最终会引发设备驱动中的poll()函数被调用。...return mask; } 三、总结 阻塞与非阻塞操作: 定义并初始化等待对列头; 定义并初始化等待队列; 把等待队列添加到等待队列头 设置进程状态(TASK_INTERRUPTIBLE(可以被信号打断

    5.5K20

    linux阻塞与非阻塞(connect连接超时)

    非阻塞connect详情介绍可以参见文章:https://blog.csdn.net/qq_41453285/article/details/89890429 一、非阻塞connect概述 man手册...解析文档,非阻塞connect如何使用: ①当我们将sock设置为非阻塞之后,使用connect去连接服务端,即使服务端开启了,connect系统调用也不会连接成功,connect而是以失败告终,并返回错误...②但是非阻塞connect返回的错误是有讲究的: 如果非阻塞connect返回的错误是EINPROGRESS,代表不是connect系统调用出错了,而是connect可能会在后面才会建立完整地连接(...,进一步来等待非阻塞connect客户端与服务端建立完整地连接,在等待的过程中,如果非阻塞connect建立成功了,客户端的sock_fd就会变成可写的(这个在本人的IO复用文章中介绍过,见下图) ④当非阻塞...在有些系统(比如Linux)上返回-1,而在有些系统上(比如源自伯克利的UNIX)返回0 这些问题没有一个统一的解决办法 三、编码演示案例 #include #include <stdlib.h

    6.5K10

    【Linux】深入 Linux 进程等待机制:阻塞与非阻塞的奥秘

    如果任意时刻调用wait/waitpid,子进程存在且正常运行,则可能阻塞。 如果不存在该进程,则立即出错放回。...sleep(5); exit(257); } else { //father int status = 0; pid_t ret = waitpid(-1,&status,0);//阻塞等待...{ //father int status = 0; pid_t ret = 0; do { ret = waitpid(-1,&status,WNOHANG);//非阻塞等待...3.解释堵塞与非堵塞 阻塞场景:打电话等朋友接听 你拨打朋友的电话,直到朋友接通之前你什么都做不了。这就像阻塞调用,你必须等着事情完成。...非阻塞场景:发消息等待回复 你给朋友发了个消息,等他们回你。你不用一直盯着手机看,而是可以去做别的事情,等收到消息后再查看。这就像非阻塞调用,你不需要等着完成才能做其他事情。

    13310

    Java网络编程——NIO的阻塞IO模式、非阻塞IO模式、IO多路复用模式的使用

    NIO虽然称为Non-Blocking IO(非阻塞IO),但它支持阻塞IO、非阻塞IO和IO多路复用模式这几种方式的使用。...IO模式跟BIO一样,最大的缺点就是阻塞。...但是在客户端有就绪事件,处理客户端的请求时,比如服务端接收客户端连接请求的过程、服务端读取数据(数据拷贝)的过程,是阻塞的。 IO多路复用模式 看完NIO非阻塞模式的使用方法你是不是就觉得万无一失了?...有,那就是IO多路复用模式,相对于上面的非阻塞模式,IO多路复用模式主要是引入了Selector选择器,且需要把Channel设置为非阻塞模式(默认是阻塞的)。...---- 转载请注明出处——胡玉洋 《Java网络编程——NIO的阻塞IO模式、非阻塞IO模式、IO多路复用模式的使用》

    51310

    Linux编程(阻塞的概念)

    阻塞。 好吧,再来一点营养。阻塞是啥意思呢? 就是水管堵住了!扭开水龙头没有水出来。...这个道理跟Linux下读取慢速设备(主要指管道和套接字)数据的情形非常相似,例如当我们在读取一个管道时,如果管道里面没有数据,那么我们什么都读不出来,于是就进入了所谓的“阻塞”状态了,说白了阻塞就是使得当前进程或者线程睡眠了的意思...那么再进一步,什么时候会阻塞呢?下面的表格简单描述了这些清空: ? 其中,读者指的是对管道文件拥有读权限的进程或线程(注意不是正在读),写者指的是对管道文件拥有写权限的进程或线程(注意不是正在写)。...除此之外,其实open()函数也会发生阻塞,比如用只读或者只写open一个管道文件的时候。因为一根只有出口或者只有入口的水管,是无法使用的呀!其实就是生活常识。嘿嘿!

    2.2K30

    从linux源码看socket的阻塞和非阻塞 顶

    从linux源码看socket的阻塞和非阻塞 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。 大部分高性能网络框架采用的是非阻塞模式。...笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。 本文源码均来自采用Linux-2.6.24内核版本。...\非阻塞状态 我们用fcntl修改socket的阻塞\非阻塞状态。...的时候 我们跟踪源码调用: socket.recv |->sys_recv |->sys_recvfrom |->sock_recvmsg |->__sock_recvmsg...阻塞后什么时候恢复运行呢 情况1:有对应的网络数据到来 首先我们看下网络分组到来的内核路径,网卡发起中断后调用netif_rx将事件挂入CPU的等待队列,并唤起软中断(soft_irq),再通过linux

    3.6K20

    stm32中阻塞模式和非阻塞模式 in blocking mode 与 in non-blocking mode区别

    HAL_I2C_Master_Transmit与HAL_I2C_Master_Transmit_IT一个是在blocking模式一个是在no-blocking 模式 阻塞模式和非阻塞模式.........我的理解是: 阻塞模式就像是一个延时函数,当这个函数没处理完那么,所有的按照流程需要执行的代码都不会被执行,要等到这个延时完成,类似 平时看书上写的LED灯闪烁,用的delay()一样.....而非阻塞模式就像他定义的那样,一般用的是中断,执行这条语句的时候,开启相应的中断达到一定的条件才进行处理,这样不会影响到流程的执行....我的理解就是,阻塞就是死等,非阻塞就是中断 可以参考 /** * @brief Sends an amount of data in non blocking mode.

    1.4K40

    嵌入式Linux:阻塞式IO与非阻塞式IO

    在Linux系统中,I/O操作可以分为两种模式:阻塞式I/O和非阻塞式I/O。 这两种模式决定了进程在执行I/O操作时的行为方式,以及CPU资源的利用效率。...1 阻塞式 I/O (Blocking I/O) 阻塞式I/O是默认的I/O操作模式。它的典型特点是,当对文件或设备进行读写操作时,如果资源当前不可用,操作系统会挂起调用者,直到资源变得可用。...2 非阻塞式 I/O (Non-blocking I/O) 非阻塞I/O则是在执行I/O操作时,不管资源是否可用,操作系统都不会让进程进入阻塞状态,而是立即返回控制权。...阻塞式 I/O 缺点: 由于进程可能长时间阻塞,会降低系统的响应性。 不适合高并发场景,因为每个阻塞的进程都会占用一个线程或进程资源。...以鼠标输入设备文件为例,Linux中鼠标对应的设备文件通常位于/dev/input/目录下,命名为mouseX(X为序号)或eventX。

    6300

    Linux下Socket网络编程send和recv使用注意事项

    2.recv函数 ssize_t recv(int s, char *buf, size_t len, int flags); (1)recv先等待s的发送缓冲中的数据被协议传送完毕,如果协议在传送s的发送缓冲...recv函数仅仅是copy数据,真正的接收数据是协议来完成的) (3)recv函数返回其实际copy的字节数。...如果recv在copy时出错,那么它返回SOCKET_ERROR;如果recv函数在等待协议接收数据时网络中断了,那么它返回0。...注意:在Unix系统下,如果recv函数在等待协议接收数据时网络断开了,那么调用recv的进程会接收到一个SIGPIPE信号,进程对该信号的默认处理是进程终止。...Q&A: (1)两次send一次recv会发生什么? 一次性读取两次send的内容。 (2)recv之后,接收缓冲区会被清空吗? 是的。

    3.1K31

    使用epoll时需要将socket设为非阻塞吗?

    一、结论 提出这个问题说明对网络编程的一些基础原理未搞明白,先说下结论: 一个 socket 是否设置为阻塞模式,只会影响到 connect/accept/send/recv 等四个 socket API...2.1 socket 是否被设置成阻塞模式对下列 API 造成的影响 当 connfd 被设置成阻塞模式时(默认行为,无需设置),connect 函数会一直阻塞到连接成功或超时或出错,超时值需要修改内核参数...,recv函数会一直阻塞直到收取到数据或者超时,有的话,取到数据后返回。...上的select函数 302 4.5.2 Windows上的select函数 317 4.6 socket的阻塞模式和非阻塞模式 318 4.6.1 如何将socket设置为非阻塞模式 318 4.6.2...send和recv函数在阻塞和非阻塞模式下的表现 320 4.6.3 非阻塞模式下send和recv函数的返回值总结 331 4.6.4 阻塞与非阻塞socket的各自适用场景 333 4.7 发送0

    2.4K10

    (四) 如何将socket设置为非阻塞模式

    另外,windows和linux平台上accept()函数返回的socekt也是阻塞的,linux另外提供了一个accept4()函数,可以直接将返回的socket设置为非阻塞模式: int accept...除了创建socket时,将socket设置成非阻塞模式,还可以通过以下API函数来设置: linux平台上可以调用fcntl()或者ioctl()函数,实例如下: fcntl(sockfd, F_SETFL.../details/44306993),linux下如果调用fcntl()设置socket为非阻塞模式,不仅要设置O_NONBLOCK模式,还需要在接收和发送数据时,需要使用MSG_DONTWAIT标志,...因为linux man手册上recv()函数的说明中关于MSG_DONTWAIT说明如下: Enables nonblocking operation; if the operation would block...,而*argp非0即可设置成非阻塞模式。

    4.6K70

    JAVA语言异步非阻塞设计模式(原理篇)

    本文首先介绍异步非阻塞模式,从线程模型的角度分析阻塞和非阻塞模式的区别。之后介绍 Promise 设计模式的应用场景及工作流程。...根据上面的分析,同步模式具有下列严重缺点: 同步阻塞模式的工作效率十分低下。...小人大部分时间都在休息,仅当投递请求、处理响应时,才偶尔醒来工作一小会;而在异步非阻塞模式下,小人从不休息,马不停蹄地投递请求、处理响应,或处理其他工作。 同步阻塞模式会带来延迟。...图片 图 1-3b 线程复用 在这一章里我们用漫画的形式,初步体验了同步阻塞模式与异步非阻塞模式,并分析了两种模式的区别。...异步非阻塞模式在 IO 密集型系统中应用非常广泛。

    95030

    【muduo源码分析】「阻塞」「非阻塞」「同步」「异步」

    muduo 基于 Reactor 模式实现,Reactor 模式也是目前大多数 Linux 端高性能网络编程框架和网络应用所选择的主要架构,例如 Redis 和 Java 的 Netty 库等。...注意:目前muduo库仅可以在Linux环境下使用,因为:陈硕大师在写muduo库时,不考虑可意志性,不跨平台,只支持Linux,不支持windows。...数据准备和数据读取 数据准备 根据系统IO操作的就绪状态,分为: 阻塞状态 非阻塞状态 大家都使用过recv这个系统API接口。这个接口默认就是阻塞式读取数据。...那么阻塞式等待数据就绪时是什么表现呢? 当数据没有准备好时,recv会阻塞式等待,造成该线程什么也做不了,就造成了线程阻塞。...数据准备 根据应用程序和内核的交互方式,分为: 同步 异步 对于同步读取数据而言,代表函数就是recv。当数据读取时,线程阻塞等待,消耗的时间属于应用程序。

    9210

    一种理解同步异步,阻塞非阻塞,Linux IO 模型,select poll epoll 的方法

    同步(synchronous)/异步(asynchronous),阻塞(blocking)/非阻塞(non-blocking),阻塞IO/非阻塞IO/同步IO/异步IO/IO复用(IO Multiplexing...同步/异步与阻塞/非阻塞的理解 线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。用线程执行程序流的过程去理解同步异步,阻塞非阻塞。...阻塞与非阻塞 线程执行过程中,产生一个外部调用后,会不会把该线程流“堵”住,会“堵”对应的是阻塞,反之为非阻塞。...Linux的五种IO模型 上一节中对同步/异步,阻塞/非阻塞的描述只能说能够恰好区分它们,如果不是在计算机领域而是生活中,道理也类似。...然而计算机中的某些专业术语又需要放在专门的情景中去看,例如下面将要提到的Linux IO模型,建议理解模型本身,而不是抠同步/异步与阻塞非阻塞的字眼,因为会发现就算是非阻塞模型也有阻塞的部分,同步IO与异步

    6.9K10
    领券