用java nio合并两个小文件的方法
By:Roy.LiuLast updated:2013-02-27
JAVA NIO 的效率比原来的IO API 效率要高,做了一个简单的测试,合并两个小文件,仅仅测试而已。不能直接用于自己的工程中。
重点关注的就是 ByteBuffer 和 ByteBuffer数组,FileChanel 可以接收一个数组类型的ByteBuffer, 从而实现了合并两个文件。
另外注意的是,我测试的from1.txt,from2.txt 文件都很小,所以能完整合并,如果都是大文件的话,这个方法只是窃取了前面1024个字节。如果要完全合并,可以一个文件一个文件的处理,就可以了。
package nio.sample.gather;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class FileGathering {
public static void main(String[] args) throws IOException {
long start = System.currentTimeMillis();
File fileIn1 = new File("C:\\from1.txt");
File fileIn2 = new File("C:\\from2.txt");
File fileOut = new File("C:\\to.txt");
FileInputStream fin1 = new FileInputStream(fileIn1);
FileInputStream fin2 = new FileInputStream(fileIn2);
FileOutputStream fout = new FileOutputStream(fileOut);
FileChannel fcIn1 = fin1.getChannel();
FileChannel fcIn2 = fin2.getChannel();
ByteBuffer[] bufferArray = new ByteBuffer[2];
bufferArray[0] = ByteBuffer.allocate(1024);
bufferArray[1] = ByteBuffer.allocate(1024);
fcIn1.read(bufferArray[0]);
fcIn2.read(bufferArray[1]);
bufferArray[0].flip();
bufferArray[1].flip();
FileChannel fcOut = fout.getChannel();
fcOut.write(bufferArray);
long end = System.currentTimeMillis();
System.out.println("time used" + (end - start));
}
}
重点关注的就是 ByteBuffer 和 ByteBuffer数组,FileChanel 可以接收一个数组类型的ByteBuffer, 从而实现了合并两个文件。
另外注意的是,我测试的from1.txt,from2.txt 文件都很小,所以能完整合并,如果都是大文件的话,这个方法只是窃取了前面1024个字节。如果要完全合并,可以一个文件一个文件的处理,就可以了。
From:一号门
Previous:java web开发获取客户端访问ip(透过代理和负载均衡)
Next:python解析xml的简单例子

COMMENTS