java中的NIO,BIO,AIO

简介: java中的NIO,BIO,AIO

IO,input和output,Java 为 I/O 提供了强大的而灵活的支持,使其更广泛地应用到文件传输和网络编程中。


IO是什么?为什么需要IO?


java在1.4之前,提供的是BIO,也就是java.io包下的的东西,同步阻塞。


在1.4之后,提供了NIO(New IO),在java.nio包下,同步非阻塞。


在java7,提供了AIO,也在java.nio.channels包下,只不过新增了几个异步通道,异步非阻塞。


IO是啥


Java中的流分为两种,一种是字节流,另一种是字符流,分别由四个抽象类来表示(每种流包括输入和输出两种所以一共四个):InputStream,OutputStream,Reader,Writer。Java中其他多种多样变化的流均是由它们派生出来的。



可以看出来,IO主要是读写东西用的,至于读写的东西从哪来到哪去,并无具体限制,所以,我们可以从文件读:FileInputStream,可以从管道读:PipedInputStream等等。


没有IO会影响什么?


我是这么理解的,没有IO的java,相当于一个不能和外界沟通的程序,我们编写一个java程序,一般都需要输入输出,而IO就是帮助我们来和程序进行交互的通道,我们在键盘上的输入通过IO传输给程序,程序的输出通过显示屏展示给我们。


没有IO,java程序也就不可能做到网络编程,只能单机自己玩,因为它无法和其他程序进行通信。


IO可以用来做什么?


  • 读写文件


  • 接口调用


  • 数据输出


  • 网络IO通信


Tomcat和Jetty与IO啥关系


tomcat6默认就使用的BIO,而且也只有BIO。


tomcat7和tomcat8都开始支持APR模式(简单理解,就是利用JNI从操作系统级别解决异步IO问题,大幅度的提高服务器的处理和响应性能,也是Tomcat运行高并发应用的首选模式。),但是观察源码就会发现,tomcat7在没有APR配置的情况下会选择BIO。tomcat8在没有检测到APR配置的情况下会选择NIO。


BIO方式适用于连接数目比较小且固定的架构,这种方式对服务器资源要求比较高,并发局限于应用中。 NIO是一个基于缓冲区、并能提供非阻塞I/O操作的Java API。适用于连接数目多且连接比较短(轻操作)的架构。 AIO(NIO2)方式使用于连接数目多且连接比较长(重操作)的架构,充分调用OS参与并发操作,编程比较复杂。


tomcat8开始支持APR利用JNI调用本地API,大幅度提高了tomcat的IO性能,是tomcat的“大杀器”,但是如果要使用APR就要安装对应 的组件。


Jetty一开始也使用的BIO,随着版本更新升级了NIO,


socket和IO啥关系


我是这样理解的,IO是socket实现的一部分,socket负责把数据从别处取过来,IO负责读取过来的数据,而且一般讨论socket和IO,这个IO会是指linux的IO,而不是java的IO,毕竟java的IO其实也只是封装了linux的IO。


供参考:Linux常见IO模型


BIO,NIO,AIO都有相对应的socket实现。


不过这篇文章和我的理解有出入,我再研究下:AIO Socket 编程 原理篇


连接数据库和IO有关系吗?


java中,连接数据库一般都是用jdbc,jdbc的底层进行连接使用socket,socket一般都是阻塞IO,也就是BIO。


but,java13的时候



但是我还没研究清楚,这算不算是使用了NIO。

目录
相关文章
|
2天前
|
存储 监控 Java
Java中的NIO编程实践精华
Java中的NIO编程实践精华
|
3天前
|
Java
Java NIO Selector
Java NIO Selector
4 0
|
3天前
|
存储 Java
Java NIO SelectionKey
Java NIO SelectionKey
7 0
|
4天前
|
存储 监控 Java
深入探索Java BIO与NIO输入输出模型:基于文件复制和socket通信
深入探索Java BIO与NIO输入输出模型:基于文件复制和socket通信
|
4天前
|
存储 监控 Java
了解Java中的NIO编程
了解Java中的NIO编程
|
5天前
|
Java 机器人 程序员
Java中的文件I/O操作:流、读写和NIO详解
Java中的文件I/O操作:流、读写和NIO详解
|
5天前
|
Java 机器人 大数据
如何在Java中进行网络编程:Socket与NIO
如何在Java中进行网络编程:Socket与NIO
|
2月前
|
存储 Java 数据处理
|
2月前
|
存储 监控 Java
深入探索Java语言的NIO(New I/O)技术
深入探索Java语言的NIO(New I/O)技术
|
16天前
|
Java 视频直播 数据库连接
Java I/O 模型详解:BIO、NIO 与 AIO 的特性与应用
Java I/O 模型详解:BIO、NIO 与 AIO 的特性与应用
20 2