java基础---->java中nio的使用(一)
JDK 1.4 中引入的新输入输出 (NIO) 库在标准 Java 代码中提供了高速的、面向块的 I/O。今天我们就简单的学习一下nio的知识。我笑,便面如春花,定是能感动人的,任他是谁。
nio的简单使用
FileInputStream、FileOutputStream和RandomAccessFile用于产生FileChannel。这些字节操纵流,与底层的nio特性一致。
一、FileChannel的产生
public void nioTest_1() {
final int BUFFER_SIZE = 1024;
try {
// 向文件里面写入数据
FileChannel fc = new FileOutputStream("file/linux.txt").getChannel();
fc.write(ByteBuffer.wrap("I love you".getBytes()));
fc.close();
// 向文件里面追加数据
fc = new RandomAccessFile("file/linux.txt", "rw").getChannel();
System.out.println(fc.position()); //
fc.position(fc.size());
fc.write(ByteBuffer.wrap(", china.".getBytes()));
fc.close();
// 向文件里面读取数据
fc = new FileInputStream("file/linux.txt").getChannel();
ByteBuffer buffer = ByteBuffer.allocate(BUFFER_SIZE);
fc.read(buffer);
buffer.flip();
while (buffer.hasRemaining()) {
System.out.print((char) buffer.get()); // I love you, china.
}
} catch (Exception e) {
e.printStackTrace();
}
}
二、文件的复制功能
public void nioTest_2() {
final int BUFFER_SIZE = 1024;
try {
FileChannel out = new FileOutputStream("file/huhx.txt").getChannel();
FileChannel in = new FileInputStream("file/linux.txt").getChannel();
ByteBuffer buffer = ByteBuffer.allocate(BUFFER_SIZE);
while (in.read(buffer) != -1) {
buffer.flip(); // 准备写数据
out.write(buffer);
buffer.clear(); // 准备读数据
}
out.close();
in.close();
} catch (Exception e) {
e.printStackTrace();
}
}
关于文件的复制,jdk提供了一个简单的方法实现。
public void nioTest_3() {
final int BUFFER_SIZE = 1024;
try {
FileChannel out = new FileOutputStream("file/huhx.txt").getChannel();
FileChannel in = new FileInputStream("file/linux.txt").getChannel();
ByteBuffer buffer = ByteBuffer.allocate(BUFFER_SIZE);
in.transferTo(0, in.size(), out);
// out.transferFrom(in, 0, in.size()); 这个和上述实现的目标是一样的。
} catch (Exception e) {
e.printStackTrace();
}
}
三、buffer之间的转换
public void nioTest_4() {
ByteBuffer buffer = ByteBuffer.wrap(new byte[]{0, 0, 0, 0, 0, 0, 0, 'a'});
buffer.rewind();
System.out.println("Byte Buffer");
while (buffer.hasRemaining()) {
System.out.println(buffer.position() + " -> " + buffer.get());
}
IntBuffer intBuffer = ((ByteBuffer) buffer.rewind()).asIntBuffer();
System.out.println("Int Buffer");
while (intBuffer.hasRemaining()) {
System.out.println(intBuffer.position() + " -> " + intBuffer.get());
}
CharBuffer charBuffer = ((ByteBuffer) buffer.rewind()).asCharBuffer();
System.out.println("Char Buffer");
while (charBuffer.hasRemaining()) {
System.out.println(charBuffer.position() + " -> " + charBuffer.get());
}
}
运行的效果:
Byte Buffer
->
->
->
->
->
->
->
->
Int Buffer
->
->
Char Buffer
->
->
->
-> a
四、存储器映射文件
public void nioTest_6() {
final int length = 0x8FFFFFF;
try {
MappedByteBuffer out = new RandomAccessFile("file/huhx.txt", "rw").getChannel().map(FileChannel.MapMode.READ_WRITE, 0, length);
for (int i = 0; i < length; i++) {
out.put((byte) 'x');
}
System.out.println("Finishing writing");
for (int i = length / 2; i < length / 2 + 6; i++) {
System.out.print((char) out.get(i));
}
} catch (Exception e) {
e.printStackTrace();
}
}
五、文件加锁
public void nioTest_7() {
try {
FileOutputStream fos = new FileOutputStream("file/huhx.txt", false);
FileLock fileLock = fos.getChannel().tryLock();
if (fileLock != null) {
System.out.println("Locked File");
Thread.sleep(1000);
fos.write("hello world".getBytes());
fileLock.release();
System.out.println("Released Lock");
}
fos.close();
} catch (Exception e) {
e.printStackTrace();
}
}
友情链接
- nio的基础概念及使用: http://blog.csdn.net/qq_21430549/article/details/52145008
- 比较详细的nio说明: http://blog.csdn.net/tzs_1041218129/article/details/54917857
java基础---->java中nio的使用(一)的更多相关文章
- Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock)
Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在学习Java的之前,你可能已经听说过读 ...
- java基础---->java中正则表达式二
跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...
- Java基础学习中一些词语和语句的使用
在Java基础学习中,我们刚接触Java会遇到一些词和语句的使用不清的情况,不能很清楚的理解它的运行效果会是怎么样的,如:break,continue在程序中运行效果及跳转位置, 1.先来看看brea ...
- Java基础-Java中的堆内存和离堆内存机制
Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
- Java基础-Java中的内存分配与回收机制
Java基础-Java中的内存分配与回收机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一. 二.
- Java基础-Java中的并法库之线程池技术
Java基础-Java中的并法库之线程池技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是线程池技术 二.
- Java基础-Java中23种设计模式之常用的设计模式
Java基础-Java中23种设计模式之常用的设计模式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.设计模式分类 设计模式是针对特定场景给出的专家级的解决方案.总的来说设 ...
- Java基础-JAVA中常见的数据结构介绍
Java基础-JAVA中常见的数据结构介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是数据结构 答:数据结构是指数据存储的组织方式.大致上分为线性表.栈(Stack) ...
- Java基础__Java中自定义集合类
Java基础__Java中集合类 传送门 自定义MyArrayList集合实现:增加数据.取数据.查看集合中数据个数方法 package com.Gary; public class MyArrayL ...
- Java基础(中)
面向对象基础 面向对象和面向过程的区别 两者的主要区别在于解决问题的方式不同: 面向过程把解决问题的过程拆成一个个方法,通过一个个方法的执行解决问题. 面向对象会先抽象出对象,然后用对象执行方法的方式 ...
随机推荐
- python --标准库 路径与文件 (os.path包, glob包)
os.path包 os.path包主要是处理路径字符串,提取出有用信息. #coding:utf-8 import os.path path = 'D:\\Python7\\test\\data.tx ...
- 深入理解MapReduce的架构及原理
1. MapReduce 定义 Hadoop 中的 MapReduce是一个使用简单的软件框架.基于它写出来的应用程序能够执行在由上千个商用机器组成的大型集群上,并以一种可靠容错式并行处理TB级别的数 ...
- Hive 指定分隔符,将表导出到本地
hive表的数据源有四种: hbase hdfs 本地 其他hive表 而hive表本身有两种: 内部表和外部表. 而hbase的数据在hive中,可以建立对应的外部表(参看hive和hbase整合) ...
- Linux下从视频提取音频的方法
Linux下可以利用mencoder将视频里的音频提取出来.方法如下: 1.首先安装mencoder.对于Ubuntu来说,软件仓库里就有mencoder,可直接输入如下命令安装 sudo apt-g ...
- Java数据结构和算法(三):常用排序算法与经典题型
常用的八种排序算法 1.直接插入排序 我们经常会到这样一类排序问题:把新的数据插入到已经排好的数据列中.将第一个数和第二个数排序,然后构成一个有序序列将第三个数插入进去,构成一个新的有序序列.对第四个 ...
- Android Studio 更新gradle插件
今天更新了CentOS, 更新了java版本. 然后gradle跪了..... 不吐槽java版本的兼容性问题了.... 反正有他自己的理由.... 那么就更新gradle咯.... 下面是方法... ...
- 【C语言】23-typedef
一.typedef作用简介 * 我们可以使用typedef关键字为各种数据类型定义一个新名字(别名). 1 #include <stdio.h> 2 3 typedef int Integ ...
- FreeRTOS——1
以下转载自安富莱电子: http://forum.armfly.com/forum.php FreeRTOS 的特点 FreeRTOS 的主要特点如下:1. 支持抢占式调度,合作式调度和时间片调度.2 ...
- CSS学习笔记(8)--纯CSS绘制三角形(各种角度)
纯CSS绘制三角形(各种角度) CSS三角形绘制方法,学会了这个,其它的也就简单. 我们的网页因为 CSS 而呈现千变万化的风格.这一看似简单的样式语言在使用中非常灵活,只要你发挥创意就能实现很多 ...
- base64变形注入与联合查询注入的爱情故事
先来写一下GET的知识点: 1.知道了convart函数(CONVERT函数是把日期转换为新数据类型的通用函数) 2.Illegal mix of collations for operation ' ...