在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
Java开发中的I/O模型原理解析,I/O是 input/output的缩写即输入输出端口。每个设备都会有一个专用的I/O地址用来处理自己的输入输出信息。常见的五种IO模型分别是:阻塞IO、非阻塞IO、多路复用IO、信号驱动IO以及异步IO。
接下来我们具体了解Java 开发中的I/O模型:
1、BIO(Blocking IO)
BIO是同步阻塞模型一个客户端连接对应一个处理线程。在BIO中accept和read方法都是阻塞操作,如果没有连接请求accept方法阻塞;如果无数据可读取read方法阻塞。

2、NIO(Non Blocking IO)
NIO是同步非阻塞模型服务端的一个线程可以处理多个请求,客户端发送的连接请求注册在多路复用器Selector上服务端线程通过轮询多路复用器查看是否有IO请求有则进行处理。

NIO的三大核心组件:
(1)Buffer:用于存储数据底层基于数组实现,针对8种基本类型提供了对应的缓冲区类。
(2)Channel:用于进行数据传输面向缓冲区进行操作支持双向传输,数据可以从Channel读取到Buffer中也可以从Buffer写到Channel中。
(3)Selector:选择器当向一个Selector中注册Channel后,Selector 内部的机制就可以自动不断地查询(Select)这些注册的Channel是否有已就绪的 I/O 事件(例如可读,可写,网络连接完成等),这样程序就可以很简单地使用一个线程高效地管理多个Channel也可以说管理多个网络连接,因此Selector也被称为多路复用器。
当某个Channel上面发生了读或者写事件,这个Channel就处于就绪状态,会被Selector监听到,然后通过SelectionKeys可以获取就绪Channel的集合进行后续的I/O操作。

Epoll是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率,获取事件的时候它无须遍历整个被侦听的描述符集,只要遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。
3、AIO(NIO 2.0)
AIO是异步非阻塞模型一般用于连接数较多且连接时间较长的应用,在读写事件完成后由回调服务去通知程序启动线程进行处理。与NIO不同,当进行读写操作时只需直接调用read或write方法即可。这两种方法均为异步的对于读操作而言,当有流可读取时操作系统会将可读的流传入read方法的缓冲区并通知应用程序;对于写操作而言当操作系统将write方法传递的流写入完毕时操作系统主动通知应用程序。可以理解为read/write方法都是异步的完成后会主动调用回调函数。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Java学习重点Java参数传递
众所周知,Java有两种参数传递方式,即按值传递和引用传递,而String类型比较特殊,需要单独讨论。Java参数传递只有值拷贝,没有引用传递。本文将讨论基本类型、引用类型和String类型。
6891
2019-08-02 18:56:51
自学Java可以找到工作吗?要学到什么程度?
Java作为备受程序员喜爱的编程语言,在各行各业都被广泛使用,导致当下越来越来多的自学者想通过自己的努力,自学Java从而找到一份高薪可以改变自己职业前途的工作。那么自学Java可以找到工作吗?要学到什么程度?其实对大多数学习者来说,自学Java都不是一个最好的选择,一方面是因为Java语言自身学习的难度比较高,另一方面是自学效率低,对自学者能力要求高。
6625
2019-10-26 11:33:24
GC垃圾回收学习笔记整理
只要掌握了GC垃圾回收的相关知识点,程序员在工作中就不用担心内存管理了,因为垃圾收集器会自动进行管理。本文为大家整理了GC垃圾回收的学习笔记,主要内容包括了判断回收条件,虚拟机频繁full GC的解决对策以及经典的垃圾回收算法。大家要是对GC垃圾回收的相关学习学习感兴趣,就接着看下去吧!
5592
2020-03-26 22:20:37
JavaWeb开发XML学习笔记整理
JavaWeb开发能力是Java程序员的必备基础能力,因此掌握它十分重要。今天本文要和大家分享的是JavaWeb开发中有关XML学习笔记的整理。主要内容包括了XML的概念、XML的语法、约束和解析。感兴趣的朋友就一起来看看吧!
5687
2020-04-03 00:40:49
Java入门基础知识点需要学什么?
入门学习一定要找到适合自己的方法才能事半功倍,对需要掌握的知识点有一个大概的了解,Java入门基础知识包含:标识符、变量、AScii码和Unicod码、基本数据类型转化String类、进制、运算符、程序流程控制语句、方法等内容。
4222
2021-03-16 11:39:10
