概述
详细
一、前言
本例子用于系统学习nio, 在介绍nio知识点过程中中, 使用以下案例
1:传统IO与NIO 代码对比与分析
2:NIO操作原理(例子:火车、车轨与车厢的举例)
3:使用NIO实现文件拷贝
4:使用NIO实现非阻塞是socket通讯
二、代码结构图
1、代码导入
下载代码导入sts编辑器,如果没有sts也可以直接导入到eclipse或者idea
2、代码结构图
三、项目运行
代码使用的junit4单元测试, 只需要代码每一个测试类, 选中要执行的方法右键运行:run as JunitTest即可。
安装学习步骤:
1>打开BufferTest类, 先执行test1方法
目的:学习nio的核心之一Buffer模块的常见api
运行效果:
2>打开ChannelTest类, 按照顺序, 先后运行test1, test2, test3, test4, test5方法
目的:学习nio核心之一Channel 的获取方式, 操作方式, 案例是文件拷贝
1:先准备一个a.avi文件
2:右键运行
3:运行结果, 多了b.avi文件, 拷贝成功
3>SelectorTest 跟 PipeTest 同理, 具体实现功能在注释已经解释。
四、项目相关资料
图片:
思维导图:
五、核心知识点解释
传统IO: 就是jdk纯原生的IO操作
NIO: jdk1.4 之后提供的新的io操作, 可以异步读取数据, 可以双向读取流
缓存区:nio 核心之一, nio操作的数据暂存在缓存区中,具体操作参考:BufferTest 类
通道:nio核心之一, nio通过缓存区操作数据, 而数据的读与写的流转需要借助通道实现。 具体操作参考:ChannelTest
选择器:nio核心之一, nio为解决非阻塞读写问题,而提出通过事件响应方式实现io操作, 选择器是其中核心组件。具体操作参考:SelectorTest类
网络IO:就是socket操作, 具体操作参考:SelectorTest类
六、部分源码
/** * 一:缓冲区:负责数据的存取,缓冲区本质是一个数组,用于存储不同类型的数据 * 根据数据类型不同(boolean除外),通过了7个缓冲区: * ByteBuffer * CharBuffer * ShortBuffer * IntBuffer * LongBuffer * FloatBuffer * DoubleBuffer * * 二:缓冲区存储数据2种核心方法 * put(): 存入数据到缓冲区中 * get(): 获取缓冲区中的数据 * * * * 三:缓冲区中四大核心属性 * capacity:容量,表示缓冲区中最大的存储数据的容量,一旦声明不能改变 * limit:界限,表示缓冲区中可以操作数据的大小.(limit后面数据无法进行读写) * position:位置,表示缓冲区中正在操作数据的位置 * mark:标记,表示标记当前position的位置,可以通过reset() 回复到mark的位置 * * 约束: * position <= limit <= capacity * * */ public class BufferTest { @Test public void test2() throws Exception { //1:分配空间 ByteBuffer buffer = ByteBuffer.allocateDirect(1024); //2:判断是否是直接缓冲区 buffer.isDirect(); } @Test public void test1() throws Exception { String str = "dafei"; //1:分配一个指定大小的缓冲区 ByteBuffer buf = ByteBuffer.allocateDirect(1024); System.out.println("-----------allocate----------------"); System.out.println(buf.capacity()); System.out.println(buf.limit()); System.out.println(buf.position()); //2:往缓冲区中存储数据 buf.put(str.getBytes()); System.out.println("----------put----------------"); System.out.println(buf.capacity()); System.out.println(buf.limit()); System.out.println(buf.position()); //3:切换读模式 buf.flip(); System.out.println("----------flip----------------"); System.out.println(buf.capacity()); System.out.println(buf.limit()); System.out.println(buf.position()); //4:获取缓冲区存放的数据 System.out.println(buf.get()); System.out.println(buf.get()); System.out.println("----------get----------------"); System.out.println(buf.capacity()); System.out.println(buf.limit()); System.out.println(buf.position()); System.out.println("----------get----------------"); buf.rewind(); buf.remaining(); System.out.println(buf.capacity()); System.out.println(buf.limit()); System.out.println(buf.position()); } }