JAVA NIO——MappedByteBuffer 分割拷贝超大文件
JAVA NIO——MappedByteBuffer 分割拷贝超大文件
?
/** * NIO —— MappedByteBuffer 分割拷贝大文件 * @throws FileNotFoundException * @throws IOException * @author sdylag * time: 2011-10-01 1:49 * * * 测试:拷贝4.96GB 电影:720p高清阿凡达178分钟加长收藏版.mkv 用时:4分钟0.1秒 * 机器配置:联想Z460 i5CPU 2.53GHz 4GB内存 500GB硬盘 1GB显存 * */public static void NioCopyFile(String sourcePath , String targetPath) throws FileNotFoundException, IOException {long before = System.currentTimeMillis();File files = new File(sourcePath);//源文件File filet = new File(targetPath);//目标文件long size = files.length(); // 文件总大小long copycount = size * 2 / Integer.MAX_VALUE; //获取读、写之和所占用虚拟内存 倍数int copynum = copycount >= 1 ? (int) copycount + 2 : (int) copycount + 1; // 根据倍数确认分割份数long countSize = Integer.MAX_VALUE / copynum; //每块分割大小<每次读写的大小>long lontemp = countSize;//初始读、写大小FileChannel channels = new RandomAccessFile(files, "r").getChannel();//得到映射读文件的通道FileChannel channelt = new RandomAccessFile(filet, "rw").getChannel();//得到映射写文件的通道long j = 0; // 每次循环累加字节的起始点MappedByteBuffer mbbs = null; // 声明读源文件对象MappedByteBuffer mbbt = null; // 声明写目标文件对象while (j < size) {mbbs = channels.map(FileChannel.MapMode.READ_ONLY, j, lontemp);//每次读源文件都重新构造对象mbbt = channelt.map(FileChannel.MapMode.READ_WRITE, j, lontemp);//每次写目标文件都重新构造对象for (int i = 0; i < lontemp; i++) {byte b = mbbs.get(i);//从源文件读取字节mbbt.put(i, b);//把字节写到目标文件中}System.gc();//手动调用 GC<必须的,否则出现异常>System.runFinalization();//运行处于挂起终止状态的所有对象的终止方法。<必须的,否则出现异常>j += lontemp;//累加每次读写的字节lontemp = size - j;//获取剩余字节lontemp = lontemp > countSize ? countSize : lontemp;//如果剩余字节 大于 每次分割字节 则 读取 每次分割字节 ,否则 读取剩余字节}System.out.println("MillTime : "+ (double) (System.currentTimeMillis() - before) / 1000 + "s");}?
1 楼 zhuchong925 2012-06-13 如果是文件分割之后,如何合成一个文件?