JavaIO进阶系列——BIO,NIO,AIO系列概述day1-1

181 篇文章 3 订阅
21 篇文章 1 订阅

JavaIO进阶系列——BIO,NIO,AIO系列概述day1-1

概述

在Java的软件设计开发中,通信架构是不可避免的,我们在进行不同系统或者不同进程之间的数据交互,或者在高并发下的通信场景下都需要用到网络通信相关的技术,对于一些经验丰富的程序员来说,Java早期的网络通信架构存在一些缺陷,其中最令人恼火的是基于性能低下的同步阻塞式的I/O通信(BIO),随着互联网开发下通信性能的高要求,Java在2002年开始支持了非阻塞式的I/O通信技术(NIO)

IO模型

就是用什么样的通道或者说是通信模式和架构进行数据的传输和接收,很大程度上决定了程序通信的性能,Java共支持3种网络编程的/IO模型:BIO、NIO、AIO
实际通信需求下,要根据不同的业务场景和性能需求决定选择不同的I/O模型

BIO模型

同步并阻塞(传统阻塞型),服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销

在这里插入图片描述

NIO模型

同步非阻塞,服务器实现模式为一个线程处理多个请求(连接),即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有I/O请求就进行处理

在这里插入图片描述

AIO模型

异步非阻塞,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理,一般适用于连接数较多且连接时间较长的应用

使用场景

  1. BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中,JDK1.4以前的唯一选择,但程序简单易理解。
  2. NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,弹幕系统,服务器间通讯等。编程比较复杂,JDK1.4开始支持。
  3. AlO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的BIONIOAIO是Java语言对操作系统的各种IO模型的封装。在文件处理时,Java的IO API实际上依赖于操作系统层面的IO操作实现。\[1\] BIO(Blocking I/O)是一种同步阻塞的I/O模式,数据的读取和写入必须阻塞在一个线程内等待其完成。Java中的BIO分为传统BIO和伪异步IO两种。传统BIO是一请求一应答的模式,而伪异步IO通过线程池固定线程的最大数量来防止资源的浪费。\[1\] NIO(Non-blocking I/O)是Java中的一种非阻塞I/O模式。相比于BIONIO使用了事件驱动的方式,通过选择器(Selector)来监听多个通道的事件,实现了一个线程处理多个通道的能力。NIO在网络编程中具有更高的效率和可扩展性,因此在实际开发中经常会使用到,比如Dubbo底层就是使用NIO行通讯。\[2\] AIO(Asynchronous I/O)是Java中的一种异步I/O模式。与BIONIO不同,AIO的读写操作是异步的,不需要阻塞等待操作完成。AIO通过回调机制来处理IO事件,可以提高系统的并发能力和响应性。\[2\] BIO模型的最大缺点是资源的浪费。在BIO模型中,每个连接都需要一个线程来处理,即使连接处于空闲状态也会占用一个线程资源。这导致在高并发场景下,BIO模型的性能和可扩展性都较差。\[3\] 总结来说,Java中的BIONIOAIO分别代表了不同的I/O模型。BIO是同步阻塞的模型,NIO是非阻塞的模型,而AIO是异步的模型。在实际开发中,可以根据具体的需求选择合适的I/O模型来提高系统的性能和可扩展性。 #### 引用[.reference_title] - *1* [Java中BIONIOAIO详解](https://blog.csdn.net/s2152637/article/details/98777686)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [详解Java中的BIONIOAIO](https://blog.csdn.net/qq_41973594/article/details/117936172)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值