Java IO、BIO、NIO、BIO
一、什么是IO/NIO:
IO:即BIO(Blocking IO);面向流的、同步阻塞式IO;(JDK1.4之前唯一的选择)
NIO:面向缓冲的、同步非阻塞式IO;三大核心部分:Selector、Channel(通道)、Buffer(缓冲区);(JDK1.4引进的,一般网络编程中用得较多)
AIO:异步非阻塞式IO;(JDK1.7引进,算较新的特性)
二、同步、异步、阻塞、非阻塞(分布式系统角度理解,较抽象):
同步异步 和 阻塞非阻塞并没有直接的关系。
同异步描述的是一种"消息机制";比如两个线程A,B,线程A请求线程B需要一些数据,然后B去给A拿数据去:(主被动关系)
1:同步机制下,线程A要定时去主动的问A数据拿来没有。
2:异步机制下,线程A请求完B,就不管了,B如果把数据拿来准备好了,由B来通知A来处理。
阻塞非阻塞:描述的是线程间请求时所处的一种状态:(能不能去做别的事)
1:阻塞:体现在A请求B,一直到到读取数据B的过程中,A线程被挂起(期间不能使用CPU),直到当前数据段获取完了。(一次while()的执行)。
2:非阻塞:体现在A请求到获取数据之间,A线程不会被挂起,从请求到准备好数据这个阶段,A可以离开去做其它事。
注:同步异步,一般我们从编程中的多线程的角度理解是:同步强调线程间的时序关系,A要在B完成后才能继续。异步则是指AB两个分工完成部分任务,两者无需关心前后完成的关系。
三、组合:
同步阻塞:Java传统的IO就是 同步阻塞,A请求B拿数据,然后A之后需要主动去询问B是否准备好了,到B准备好了数据并且A获取到了数据期间,A不能干别的事,直到A获取完数据。
同步非阻塞:Java中的NIO就是 同步非阻塞,A需要主动去询问B是否准备好了,与同步阻塞的区别在于,A询问B之间A可以不阻塞,A可以去做别的事。
异步阻塞:A请求B拿数据,然后A不需要主动去询问B是否准备好了,到B准备好了数据会通知A来获取,因为也是阻塞,A也不能干别的事,直到A获取完数据。(理论是这样,但现实中这样的应用应该不多。。)
异步非阻塞:Java中的AIO就是 异步非阻塞,A请求B拿数据,然后A不需要主动去询问B是否准备好了,到B准备好了数据会通知A来获取,因为是非阻塞,A第一次请求B去拿数据后,A可以去做别的了。
四:Java nio的好处(同步非阻塞):
整体结构使用了反应器的设计模式(Reactor):
参考:Reactor模式详解

在实际使用中,Java NIO的优点主要体现在高并发时,其中Selector充当请求和询问者的角色,Selector会和多个Channel绑定,询问哪个Channel准备好了,如果有监听到需要的事件,就执行对应的操作。
之前提到的 非阻塞时做别的事,在这里可以理解为Selector去询问完当前的Channel,它这时可以去询问其它的Channel,而不用守在一个Channel前直到处理完这个Channel的数据。
五、编程中的while()方法与阻塞:
阻塞与否不是体现在这里的while()方法,在while()执行时其它已经说明请求已经准备好了;
阻塞是体现在第一次讲求读取数据并执行IO中的read()\write()方法的过程,这个过程中线程A不能做别的事。
执行while()的日的是为了读取完想要的数据,while()执行了多少次,阻塞就发生了多少次。
可参考:
同步阻塞、同步非阻塞、异步阻塞、异步非阻塞(知乎第二个郭无心答案)
Java IO、BIO、NIO、BIO的更多相关文章
- [转帖]JAVA BIO与NIO、AIO的区别(这个容易理解)
JAVA BIO与NIO.AIO的区别(这个容易理解) https://blog.csdn.net/ty497122758/article/details/78979302 2018-01-05 11 ...
- BIO与NIO、AIO的区别(这个容易理解)
转自:http://blog.csdn.net/skiof007/article/details/52873421 BIO与NIO.AIO的区别(这个容易理解) IO的方式通常分为几种,同步阻塞的BI ...
- JAVA BIO与NIO、AIO的区别
IO的方式通常分为几种,同步阻塞的BIO.同步非阻塞的NIO.异步非阻塞的AIO. 一.BIO 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个ServerSock ...
- 【转】JAVA BIO与NIO、AIO的区别
Java中IO的模型分为三种,同步阻塞的BIO.同步非阻塞的NIO.异步非阻塞的AIO. BIO[同步阻塞] 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个Ser ...
- BIO与NIO、AIO的区别
IO的方式通常分为几种,同步阻塞的BIO.同步非阻塞的NIO.异步非阻塞的AIO. 一.BIO 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个Serve ...
- [转帖] BIO与NIO、AIO的区别
培训里面讲的东西 自己查了下 啥意思,,, 转帖强化一下. http://blog.csdn.net/skiof007/article/details/52873421 IO的方式通常分为几种,同步 ...
- BIO与NIO、AIO的区别(转)
IO的方式通常分为几种,同步阻塞的BIO.同步非阻塞的NIO.异步非阻塞的AIO. 一.BIO 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个ServerSock ...
- 【1】BIO与NIO、AIO的区别
一.BIO 在JDK1.4出来之前,我们建立网络连接的时候采用BIO模式,需要先在服务端启动一个ServerSocket,然后在客户端启动Socket来对服务端进行通信,默认情况下服务端需要对每个请求 ...
- java.io中的System.in、 System.out和System.err
System.in, System.out, System.err这3个流同样是常见的数据来源和数据流目的地.使用最多的可能是在控制台程序里利用System.out将输出打印到控制台上. JVM启动的 ...
- java io 处理流,BufferdInputStream、BufferedWriter、BufferedReader
BufferdInputStream:读取helloworld.java helloworld.java: package io; public class HelloWorld { public s ...
随机推荐
- 【倒跑并查集维护连通块】NCPC 2016 A. Artwork
http://codeforces.com/gym/101550/attachments [AC] #include<bits/stdc++.h> using namespace std; ...
- SHUoj 神无月排位赛
神无月排位赛 发布时间: 2017年7月8日 21:06 最后更新: 2017年7月8日 22:35 时间限制: 1000ms 内存限制: 128M 描述 <神无月>作为盛大游 ...
- Day 8 Linux之Day8
Linux 之 Day 8 一.Linux网络原理及基础设置 1. 使用ifconfig命令来维护网络 1) ifconfig命令的功能:显示所有正在启动的网卡的详细信息或设定系统中网卡的IP地址. ...
- golang导出Excel表格
设置样式: package main import ( "github.com/tealeg/xlsx" "fmt" ) func main() { var f ...
- Raft算法详解
一致性算法Raft详解 背景 熟悉或了解分布性系统的开发者都知道一致性算法的重要性,Paxos一致性算法从90年提出到现在已经有二十几年了,而Paxos流程太过于繁杂实现起来也比较复杂,可能也是以为过 ...
- 2018.11.7 PION 模拟赛
期望:100 + 80 + 75 = 255 实际:0 + 80 + 60 = 140 唉~一天比一天犯的错误智障,感觉noip要凉啊... 吓得我赶紧吃几颗药补补脑子. 奶一下大佬: lgj AK ...
- iinflux数据库使用
特殊用法: http://blog.fatedier.com/2016/07/05/research-of-time-series-database-influxdb/ 创建表及表中的key和valu ...
- Go -- log4go日志
折腾: [已解决]go语言中实现log信息同时输出到文件和控制台(命令行) 期间,已经通过io的MultiWriter搞定了同时输出信息到文件和console,但是不支持level. 所以,再去试试这 ...
- 转: DNS 原理入门 (from 阮一峰)
转自:http://www.ruanyifeng.com/blog/2016/06/dns.html DNS 原理入门 作者: 阮一峰 日期: 2016年6月16日 DNS 是互联网核心协议之一. ...
- HDOJ 4003 Find Metal Mineral
题意: 一棵有权树,从根结点中放入 K 个机器人.求用这 K 个机器人遍历全部的结点最少的权值和. 思路: 1. dp[u][i] 表示给以 u 为根节点的子树放 i 个机器人,遍历其子树所须要的最小 ...