博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JDK中NIO
阅读量:4504 次
发布时间:2019-06-08

本文共 1372 字,大约阅读时间需要 4 分钟。

不知何时起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方法返回读取的字节数,可能为零,如果该通道已到达流的末尾,则返回-1			if (r == -1) {				break;			}			// flip方法让缓冲区可以将新读入的数据写入另一个通道			buffer.flip();			// 从输出通道中将数据写入缓冲区			fcout.write(buffer);		}	}}

 

转载于:https://www.cnblogs.com/whuqin/archive/2011/10/24/4982055.html

你可能感兴趣的文章
温故知新 javascript 正则表达式(转载)
查看>>
XP系统无法远程桌面
查看>>
正确使用索引
查看>>
java多态
查看>>
盒覆盖 算法
查看>>
bzoj1260 [CQOI2007]涂色paint
查看>>
仿网上银行虚拟键盘脚本- keyboard.js
查看>>
makefile "=" ":=" "?=" "+="
查看>>
机会是留给有准备的人
查看>>
实战是最好的学习方式
查看>>
使用qemu-img创建虚拟磁盘文件
查看>>
JDBC
查看>>
POJ - 3237 Tree (树链剖分+线段树)
查看>>
个人网站可参考的资料
查看>>
跟随一条insert语句, 进入TiDB的源码世界(上)
查看>>
软件工程-设计
查看>>
乘法游戏
查看>>
JavaScript返回上一页并自动刷新
查看>>
Linux相关——关于文件调用
查看>>
判断链表是否有环
查看>>