系统学习NIO
概述
详细
一、前言
本例子用于系统学习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()); }
}
注:本文著作权归作者,由demo大师发表,拒绝转载,转载需要作者授权
系统学习NIO的更多相关文章
- 系统学习 Java IO ---- 目录,概览
Java IO 类的系统教程,原创.主要参考自英文教程 Java IO Tutorial 和 Java Doc. http://tutorials.jenkov.com/java-io/index.h ...
- 零基础如何系统学习Java Web
零基础如何系统学习Java Web? 我来给你说一说 你要下决心,我要转行做开发,这样你才能学成. 你要会打字,我公司原来有一个程序员,打字都是两个手一指禅,身为程序员你一指禅怎么写出的代码,半个 ...
- Unity3D 装备系统学习Inventory Pro 2.1.2 基础篇
前言 前一篇 Unity3D 装备系统学习Inventory Pro 2.1.2 总结 基本泛泛的对于Inventory Pro 这个插件进行了讲解,主要是想提炼下通用装备系统结构和类体系.前两天又读 ...
- MES系统学习
MES系统是当今制造型企业信息化的热点,而统一建模语言UML是面向对象建模的标准语言,在软件工程发挥着重要作用.MES系统如何进行UML建模呢,今天和大家重点讨论一下MES系统的UML建模方法,请看本 ...
- 001 今天开始系统学习C#
2016-01-16 之前只是大概了解过c#语言,感觉掌握不牢靠.现在开始系统学习C#.现以该博客作为学习笔记,方便后续查看.C# 目标:系统掌握c#知识 时间:30天 范围:C#基础,Winform ...
- Linux系统学习笔记:文件I/O
Linux支持C语言中的标准I/O函数,同时它还提供了一套SUS标准的I/O库函数.和标准I/O不同,UNIX的I/O函数是不带缓冲的,即每个读写都调用内核中的一个系统调用.本篇总结UNIX的I/O并 ...
- Hibernate的系统 学习
Hibernate的系统 学习 一.Hibernate的介绍 1.什么是Hibernate? 首先,hibernate是数据持久层的一个轻量级框架.数据持久层的框架有很多比如:iBATIS,myBat ...
- css系统学习网站
最近系统学习一下css样式,找到一个不错的网站.http://css.doyoe.com/
- Ubuntu LTS 系统学习使用体会和实用工具软件汇总 6.04 8.04 10.04 12.04 14.04 16.04
Ubuntu LTS 系统学习体会和工具软件汇总 6.04 8.04 10.04 12.04 14.04 16.04 ubuntu入门必备pdf:http://download.csdn.net/de ...
随机推荐
- 2349 Arctic Network(中文版)
试题描述: 国防部希望通过无线网络连接几个北方前哨基地. 在建立网络时将使用两种不同的通信技术:每个前哨基站都将拥有无线电收发器,另外还有一些前哨卫星通道. 任何带卫星频道的两个前哨都可以通过卫星进行 ...
- HDU 5642 King's Order 动态规划
King's Order 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5642 Description After the king's speec ...
- hdu 2795 Billboard 线段树单点更新
Billboard Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=279 ...
- leetcode132. Palindrome Partitioning II
leetcode132. Palindrome Partitioning II 题意: 给定一个字符串s,分区使分区的每个子字符串都是回文. 返回对于s的回文分割所需的最小削减. 例如,给定s =&q ...
- java 中hashcode 与 equals的关系
equals()相等的两个对象,hashcode()一定相等: equals()不相等的两个对象,却并不能证明他们的hashcode()不相等. 反过来: hashcode()不等,一定能推出equa ...
- STM32 Hardware Development
http://www.st.com/web/en/resource/technical/document/application_note/CD00164185.pdf AN2586 http://w ...
- /etc/fstab 解析
http://www.codesec.net/view/39930.html root@qs-wg-db1 /]# cat /etc/fstab LABEL=/ / ext3 defaults 1 1 ...
- Sublime的中文GBK显示乱码的解决方法
import urllib2,os,hashlib; h = '7183a2d3e96f11eeadd761d777e62404' + 'e330c659d4bb41d3bdf022e94cab3cd ...
- BusyBox 简化嵌入式 Linux 系统
BusyBox 是很多标准 Linux® 工具的一个单个可执行实现.BusyBox 包含了一些简单的工具,例如 cat 和 echo,还包含了一些更大.更复杂的工具,例如 grep.find.moun ...
- 【mysql】mysql统计查询count的效率优化问题
mysql统计查询count的效率优化问题 涉及到一个问题 就是 mysql的二级索引的问题,聚簇索引和非聚簇索引 引申地址:https://www.cnblogs.com/sxdcgaq8080/p ...