Java NIO学习笔记一 Java NIO概述
Java NIO概述
Java NIO(新的IO)是Java的替代IO API(来自Java 1.4),这意味着替代标准的 java IO和java Networking API。Java NIO提供了与标准IO API不同的IO工作方式。
Java NIO由以下核心组件组成:
- 通道
- 缓冲区
- 选择器
除了Channel,Buffer 并Selector,Java NIO还有其他更多的类和组件。但是Channel,Buffer 和Selector构成了Java NIO API的核心。我认为,其他的组件,像 Pipe和FileLock只是结合三个核心组件一起使用的工具类。因此,本章我将重点介绍NIO概述中的这三个核心组件。
通道和缓冲区
通常,NIO中的所有IO都以一个通道开始。通道有点像流。数据从通道可以读入缓冲区。数据也可以从一个缓冲区写入通道。
在标准IO API中,你编码使用是字节流和字符流。在NIO中,你编码使用是通道和缓冲区。使用NIO读取数据,数据总是从通道读入缓冲区,或从缓冲区写入通道。
如图:
![]() |
| Java NIO:通道将数据读入缓冲区,缓冲区将数据写入通道 |
Channel和Buffer有几种类型。以下是通道在Java NIO 主要实现的列表:
- FileChannel
- DatagramChannel
- SocketChannel
- ServerSocketChannel
通过上面的实现可以看出,这些通道涵盖UDP + TCP网络IO和文件IO。
还有一些有趣的接口也伴随着这些类,但是为了方便理解,我将把它们放在Java NIO概述之外。将在相关的Java NIO教程的其他文本中进行说明。
下面是缓冲区Java NIO 中的核心实现的列表:
- ByteBuffer
- CharBuffer
- DoubleBuffer
- FloatBuffer
- IntBuffer
- LongBuffer
- ShortBuffer
这些Buffer覆盖了您可以通过IO发送的基本数据类型:byte,short,int,long,float,double和characters。Java NIO还具有一个MappedByteBuffer,是与内存映射文件配合使用的。
Java NIO:非阻塞IO
Java NIO支持执行非阻塞IO。例如,线程访问一个通道将数据读入到缓冲区。当通道将数据读入缓冲区时,线程还可以执行其他操作。一旦数据读入缓冲区,线程就可以继续处理它。线程执行将数据写入通道也是如此。
选择器
Java NIO还有一个新的概念“选择器”。选择器是一个能够监视事件的多个通道的对象(例如:打开连接,数据到达等等)。因此,单线程可以监视多个通道的数据。
一个选择器允许单个线程处理多个通道。如果您的应用程序有许多连接(通道)打开,但每个连接的流量都比较低,这是方便的。例如,在聊天服务器中。
如图:一个线程使用一个选择器来处理3个通道的:
![]() |
| Java NIO:A Thread uses a Selector to handle 3 Channel's |
注册一个通道来使用选择器。称之为 select()方法。该方法将阻塞,直到有一个注册通道的事件准备就绪。一旦方法有返回值,线程就可以处理这些事件。通道事件是传入连接,数据接收等
Java NIO学习笔记一 Java NIO概述的更多相关文章
- Java NIO 学习笔记(一)----概述,Channel/Buffer
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java IO学习笔记六:NIO到多路复用
作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...
- [原创]java WEB学习笔记51:国际化 概述,API 之 locale类,dataFormat类,numberFormat类, MessageFormat类,ResourceBundle 类
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- Java基础学习笔记一 Java介绍
java语言概述 Java是sun公司开发的一门编程语言,目前被Oracle公司收购,编程语言就是用来编写软件的. Java的应用 开发QQ.迅雷程序(桌面应用软件) 淘宝.京东(互联网应用软件) 安 ...
- Java基础学习笔记十 Java基础语法之final、static、匿名对象、内部类
final关键字 继承的出现提高了代码的复用性,并方便开发.但随之也有问题,有些类在描述完之后,不想被继承,或者有些类中的部分方法功能是固定的,不想让子类重写.可是当子类继承了这些特殊类之后,就可以对 ...
- Android(java)学习笔记89:泛型概述和基本使用
package cn.itcast_01; import java.util.ArrayList; import java.util.Iterator; /* * ArrayList存储字符串并遍历 ...
- Android(java)学习笔记28:泛型概述和基本使用
1. 泛型的概述和基本使用: package cn.itcast_01; import java.util.ArrayList; import java.util.Iterator; /* * Arr ...
- Java基础学习笔记四 Java基础语法
数组 数组的需求 现在需要统计某公司员工的工资情况,例如计算平均工资.最高工资等.假设该公司有50名员工,用前面所学的知识完成,那么程序首先需要声明50个变量来分别记住每位员工的工资,这样做会显得很麻 ...
- Java基础学习笔记六 Java基础语法之类和ArrayList
引用数据类型 引用数据类型分类,提到引用数据类型(类),其实我们对它并不陌生,如使用过的Scanner类.Random类.我们可以把类的类型为两种: 第一种,Java为我们提供好的类,如Scanner ...
随机推荐
- seajs加载jquery提示$ is not a function
jquery1.7以上的都支持模块化加载,只是jquery默认的是支持amd,不支持cmd.所以要用seajs加载jquery,需要稍微改下jquery 把 if (typeof define === ...
- TC SRM683 Div1 250
大意是有一排石子,每一堆有a[i]个,目标状态每一堆有b[i]个,每一步可以从一堆中取出一个石子转移到相邻的一个,其中1和n也算相邻也即环形.问最少步数. 比赛的时候写了个按照步数贪心的做法,FST了 ...
- LeetCode 207. Course Schedule(拓扑排序)
题目 There are a total of n courses you have to take, labeled from 0 to n - 1. Some courses may have p ...
- C#中 dynamic 关键字
所有表达式都能隐式的转换成dynamic,因为所有的表达式最终都能生成从Object派生出的类型. ; int b = a; //隐式转换错误 int b2 = (int)a; ; int b3 ...
- bzoj100题
蒟蒻选手bzoj终于100题辣!!!好鸡冻啊!!! 200题大关也来了,不知道还要多久..
- Python CGI编程(转自易百)
Python CGI编程 Python的CGI编程,公共网关接口或CGI,Web服务器和一个自定义的脚本之间交换信息是一组定义的标准. 什么是CGI ? 公共网关接口或CGI,Web服务器和一 ...
- java文件的读写操作
java文件的读写操作主要是对输入流和输出流的操作,由于流的分类很多,所以概念很容易模糊,基于此,对于流的读写操作做一个小结. 1.根据数据的流向来分: 输出流:是用来写数据的,是由程序(内存)--- ...
- leetcode contest 20
Q1: 520. Detect Capital Given a word, you need to judge whether the usage of capitals in it is right ...
- druid抛出的异常------javax.management.InstanceAlreadyExistsException引发的一系列探索
最近项目中有个定时任务的需求,定时检查mysql数据与etcd数据的一致性,具体实现细节就不说了,今天要说的就是实现过程中遇到了druid抛出的异常,以及解决的过程 异常 异常详细信息 五月 05, ...
- Docker - 访问容器
容器具有自己的内部网络和ip地址,具体信息可以查看docker inspect命令结果的"NetworkSettings"部分. 如果想要从外部访问容器中的应用,可以通过docke ...

