Java NIO 读写文件
来源:互联网 发布:python 灰帽子 编辑:程序博客网 时间:2024/05/20 06:28
1.读取文件涉及三个步骤:(1) 从FileInputStream获取 Channel,(2) 创建 Buffer,(3) 将数据从 Channel 读到 Buffer 中;
import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.nio.ByteBuffer;import java.nio.channels.FileChannel;public class NioReader {public static void main(String[] args){try {//获取文件FileInputStream fin = new FileInputStream("E:\\nioTest.txt");//获取通道FileChannel channel = fin.getChannel();//创建缓冲区ByteBuffer buffer = ByteBuffer.allocate(1024);while(channel.read(buffer) != -1){buffer.flip();//注意要使用buffer.limit()作为大小否则会读取到多余的数据System.out.print(new String(buffer.array(), 0, buffer.limit(), "utf-8"));buffer.clear();}} catch (FileNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}
2.写文件涉及三个步骤:(1) 从FileOutputStream获取 Channel,(2) 创建 Buffer,(3) 将数据写入到 Buffer 中,
import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.UnsupportedEncodingException;import java.nio.ByteBuffer;import java.nio.channels.FileChannel;public class NioWriter {public static void main(String[] args) {// TODO Auto-generated method stub//要写入的文件内容String message = "字节缓冲区要么是直接的,要么是非直接的。如果为直接字节缓冲区,"+ "则 Java 虚拟机会尽最大努力直接在此缓冲区上执行本机 I/O 操作。也就是说,在每次调用基础操作系统的一个本机 I/O 操作之前(或之后),"+ "虚拟机都会尽量避免将缓冲区的内容复制到中间缓冲区中(或从中间缓冲区中复制内容)。 "+ "\n直接字节缓冲区可以通过调用此类的 allocateDirect 工厂方法来创建。"+ "此方法返回的缓冲区进行分配和取消分配所需成本通常高于非直接缓冲区。直接缓冲区的内容可以驻留在常规的垃圾回收堆之外,"+ "因此,它们对应用程序的内存需求量造成的影响可能并不明显。所以,"+ "建议将直接缓冲区主要分配给那些易受基础系统的本机 I/O 操作影响的大型、持久的缓冲区。一般情况下,"+ "最好仅在直接缓冲区能在程序性能方面带来明显好处时分配它们。 \n直接字节缓冲区还可以通过 mapping将文件区域直接映射到内存中来创建。"+ "Java 平台的实现有助于通过 JNI 从本机代码创建直接字节缓冲区。如果以上这些缓冲区中的某个缓冲区实例指的是不可访问的内存区域,"+ "则试图访问该区域不会更改该缓冲区的内容,并且将会在访问期间或稍后的某个时间导致抛出不确定的异常。 "+ "\n字节缓冲区是直接缓冲区还是非直接缓冲区可通过调用其 isDirect 方法来确定。"+ "提供此方法是为了能够在性能关键型代码中执行显式缓冲区管理。 ";try {byte[] arr = message.getBytes("utf-8");//获取文件FileOutputStream fout = new FileOutputStream("E:\\nioTest2.txt");//获取通道FileChannel channel = fout.getChannel();//创建缓冲区ByteBuffer buffer = ByteBuffer.allocate(arr.length);buffer.put(arr);buffer.flip();//写入文件channel.write(buffer);//清空缓冲区buffer.clear();} catch (FileNotFoundException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (UnsupportedEncodingException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}
参照资料:http://www.ibm.com/developerworks/cn/education/java/j-nio/
0 0
- Java NIO 读写文件
- java NIO读写文件
- java NIO读写文件
- JAVA NIO 读写文件
- java nio实现读写文件
- Java nio(文件读写 实例解析)
- Java Nio实现socket读写文件
- java读写文件时nio、bio对比
- Java Nio实现socket读写文件
- java:NIO读写文件的示例
- 备份:nio文件读写
- NIO文件读写操作
- 使用NIO读写文件
- NIO读写文件
- nio 读写文件
- NIO读写文件示例
- JAVA NIO文件映射、通道、流读写文件示例
- 疑问:调用Java NIO提高文件读写速度
- Unable to instantiate fragment make sure class name....
- 杨辉三角的规律
- 网站图片服务器架构的演进
- Asynctask onPostExecute未执行的问题分析
- 伪元素和伪类的区别
- Java NIO 读写文件
- build_native.sh文件记录(1)
- ARM-Linux配置DHCP自动获取IP地址
- Eclipse中10个最有用的快捷键组合
- POJ 3414 Pots
- 类的交叉引用(或头文件依赖与交叉包含)
- opencv 3.0 imread 安全版 opencv最简单的例子
- vmware:完全开启虚拟化,却无法启动虚拟机,提示二进制转换与此平台长模式不兼容
- Unity3d IOS 64 IL2CPP迁移之 AStarPath JosnFX 错误