JDK中NIO
来源:互联网 发布:图片尺寸标注软件 编辑:程序博客网 时间:2024/05/17 07:56
不知何时起NIO成了众考官青睐的问题!而本人之前都没碰到过。。。。。。
NIO-new I/O,是在JDK 1.4开始引进的。主要包括java.nio,java.nio.channels,java.nio.channels.spi,java.nio.charset,java.nio.charset.spi。
特性-
为所有的原始类型提供 (Buffer) 缓存支持。
提供字符集编码解码解决方案。
两个核心抽象:
抽象类Buffer:一块连续的内存。缓冲区是特定基本类型元素的线性有限序列。除内容外,基本属性还有容量、限制和位置。
接口Channel:用于IO操作的连接。表示输出实体或输入实体。支持锁和内存映射文件的文件访问接口。
提供多路 (non-blocking) 非阻塞式的高伸缩性网络 I/O 。普通IO为阻塞式,如调用in.read(buf)时,线程会停止在那里等待内容。而NIO不会等待,线程会继续运行,当IO事件发生时,再调度。
NIO读取的基本单位是特定基本数据类型。
使用例子
package sample;import java.io.FileInputStream;import java.io.FileOutputStream;import java.nio.ByteBuffer;import java.nio.channels.FileChannel;public class CopyFile {public static void main(String[] args) throws Exception {String infile = "C:\\copy.sql";String outfile = "C:\\copy.txt";// 获取源文件和目标文件的输入输出流FileInputStream fin = new FileInputStream(infile);FileOutputStream fout = new FileOutputStream(outfile);// 获取输入输出通道FileChannel fcin = fin.getChannel();FileChannel fcout = fout.getChannel();// 创建缓冲区ByteBuffer buffer = ByteBuffer.allocate(1024);while (true) {// clear方法重设缓冲区,使它可以接受读入的数据buffer.clear();// 从输入通道中将数据读到缓冲区int r = fcin.read(buffer);// read方法返回读取的字节数,可能为零,如果该通道已到达流的末尾,则返回-1if (r == -1) {break;}// flip方法让缓冲区可以将新读入的数据写入另一个通道buffer.flip();// 从输出通道中将数据写入缓冲区fcout.write(buffer);}}}
- JDK中NIO
- 我对于 JDK中 BIO/NIO/AIO 的理解
- JDK学习-IO/NIO
- NIO中,java.nio.charset.MalformedInputException
- java中NIO总结
- JAVA NIO技术(中)
- NIO中ByteBuffer图解
- NIO中通道(Channel)
- jdk 源码分析(20)java NIO包简单分析
- Java中nio与buffer
- nio中directMemory的释放
- java中 immutable,future,nio
- Java NIO教程(中)
- java中BIO,NIO,AIO
- Java中IO与NIO
- Java中NIO技术学习
- Java中BIO NIO AIO
- Java中BIO,NIO,AIO
- css expression 使用注意
- jquery.js和json.js冲突的问题
- 如何修改linux的主机名
- DLL中使用资源
- Js&Jquery文档加载完事件
- JDK中NIO
- DLL导出资源问题的解决
- bpc动态表名
- Linux开机程序内幕(1)
- 为无LIB的DLL制作LIB函数符号输入库
- struts1 标签
- 黑马程序员-北漂
- 链表的知识结构图
- 移民加拿大还是美国不得不做的比较