五分钟理解NIO与BIO

news/2025/1/15 5:15:50/

java NIO与BIO的区别?

BIO -- Blocking IO 即阻塞式 IO。
NIO -- Non-Blocking IO, 即非阻塞式 IO 或异步 IO。

BIO 基于字节流和字符流进行操作,数据的读取写入必须阻塞在一个线程内等待其完成。

NIO 主要有三大核心部分:

  • Channel (通道):所有的 NIO 操作始于通道,通道是数据来源或数据写入的目的地。
  • Buffer (缓冲区):一个 Buffer 本质上是内存中的一块,我们可以将数据写入这块内存,之后从这块内存获取数据
  • Selector (选择器、多路复用器):多路复用,用于实现一个线程管理多个 Channel

NIO 基于 Channel 和 Buffer 进行操作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。Selector 用于监听多个通道的事件(比如:连接打开,数据到达)。因此,单个线程可以监听多个数据通道,处理多个事件。

综上,它们之间的区别有:
1、BIO,面向流的,只能读或者只能写,同步阻塞 IO 模式
2、NIO,面向块的(缓冲区),可以同时进行读写,同步阻塞 IO 模式

 

同步阻塞、同步非阻塞、异步的区别?

同步阻塞:调用者发出请求后会一直等待结果

同步非阻塞:调用者发出请求后就去执行其他任务,过一会再询问被调用者执行结果

异步:当一个异步过程调用发出后,调用者不会立即得到结果。而是在“发出后”,“被调用者“通过状态,来通知调用者,或通过回调函数处理这个调用

阻塞式IO、非阻塞式IO甚至包括多路复用IO都是基于操作系统级别对“同步IO”的实现


 



 


http://www.ppmy.cn/news/998910.html

相关文章

spring boot 集成rocketmq

集成Spring Boot和RocketMQ 在现代的微服务架构中,消息队列已经成为一种常见的异步处理模式,它能解决服务间的同步调用、耦合度高、流量高峰等问题。RocketMQ是阿里巴巴开源的一款消息中间件,性能优秀,功能齐全,被广泛…

Spring 容器原始 Bean 是如何创建的?

以下内容基于 Spring6.0.4。 这个话题其实非常庞大,我本来想从 getBean 方法讲起,但一想这样讲完估计很多小伙伴就懵了,所以我们还是一步一步来,今天我主要是想和小伙伴们讲讲 Spring 容器创建 Bean 最最核心的 createBeanInstan…

3D Web轻量化渲染开发工具HOOPS Communicator是什么?

HOOPS Communicator是Tech Soft 3D旗下的主流产品之一,具有强大的、专用的高性能图形内核,是一款专注于基于Web端的高级3D工程应用程序。由HOOPS Server和HOOPS Web Viewer两大部分组成,提供了HOOPS Convertrer、Data Authoring的模型转换和编…

【JavaWeb】知识

1.JSP: 1) ${pageContext.request.contextPath}的理解和用法

ubuntu samba 配置常见问题

samba配置: sudo vi /etc/samba/smb.conf [xxx 共享文件名] comment share folder browseable yes writable yes guest ok yes path /workdir/code/favarite create mask 0777 directory mask 0777 sudo /etc/init.d/smbd restart 重启smb服务 以上操作…

网络安全知识点整理(作业2)

目录 一、js函数声明->function 第一种 第二种 第三种 二、this关键字 this使用场合 1.全局环境 2.构造函数 3.对象的方法 避免多层this 三、js的同步与异步 定时器 setTimeout和setInterval 同步与异步的例子 四、宏任务与微任务 分辨宏任务与微任务 一、js…

Kafka3.0.0版本——Broker(总体工作流程)

目录 一、Kafka中Broker总体工作流程图解二、Kafka中Broker总体工作流程步骤解析 一、Kafka中Broker总体工作流程图解 总体工作流程图解 二、Kafka中Broker总体工作流程步骤解析 1、broker启动后在zk中注册,如下图所示: 2、controller谁先注册&…

cc2652主协处理器分时控制同一个外设的问题

问题已提交TI论坛,我是提交到的中文论坛,然后fae给转到英文论坛了。 简单描述就是,怎么让这个单片机一会用主处理器控制SPI设备,一会再用协处理器控制同一个设备。 主处理器的spi配置使用 CCS studio配置的 协处理器使用Sensor Co…