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 ...
随机推荐
- Spring事务管理的实现方式之编程式事务与声明式事务详解
原创说明:本博文为原创作品,绝非他处转载,转载请联系博主 1.上篇文章讲解了Spring事务的传播级别与隔离级别,以及分布式事务的简单配置,点击回看上篇文章 2.编程式事务:编码方式实现事务管理(代码 ...
- openresty源码剖析——lua代码的加载
##Openresty是什么 OpenResty是一个基于 Nginx 与 Lua 的高性能 Web 平台,通过把lua嵌入到Nginx中,使得我们可以用轻巧的lua语言进行nginx的相关开发,处理 ...
- AOJ/数据结构习题集
ALDS1_3_A-Stack. Description: Write a program which reads an expression in the Reverse Polish notati ...
- [内存管理]linux内存管理 之 内存节点和内存分区
Linux支持多种硬件体系结构,因此Linux必须采用通用的方法来描述内存,以方便对内存进行管理.为此,Linux有了内存节点.内存区.页框的概念,这些概念也是一目了然的. 内存节点:主要依据CPU访 ...
- dva框架使用mock.js模拟数据 + fetch请求数据
what DVA? Dva是基于Redux做了一层封装,对于React的state管理,有很多方案,我选择了轻量.简单的Dva. dva 可以很方便就使用mock.js进行数据的模拟. 只需要三步,即 ...
- python音频处理用到的操作
作者:桂. 时间:2017-05-03 12:18:46 链接:http://www.cnblogs.com/xingshansi/p/6799994.html 前言 本文主要记录python下音频 ...
- 让div自适应浏览器窗口居中显示
今天做 banner 时发现一个问题,就是浏览器窗口水平拉伸时 banner 图未能居中,所以网上找了些资料,自己写了个小 demo html代码: <div class="div1& ...
- 使用CSS3中的input标签与lable标签组合实现banner图的切换
在做网页时,我们经常可以碰到banner图的切换.对于那些JS薄弱的同学来说,这就很尴尬了.今天,我来告诉大家如何使用CSS做出banner图切换的效果. 这里,用到了lable标签与input的组合 ...
- DIV+CSS 规范命名集合
一: 命名规范说明: 1).所有的命名最好都小写 2).属性的值一定要用双引号("")括起来,且一定要有值如class="divcss5",id="d ...
- GitHub的实践
GitHub的实践 2017-05-08,晴,来小米已经一周的时间了,感谢领导能给我一周的时间来熟悉 ubuntu.spring boot.maven.docker.github .大家会问,这些不都 ...