**
【java】采用RandomAccessFile对文件的分片与合并
**
// 简介
RandomAccessFile是一个古老的类,它和inputstream outputstream 类系没有关系,它的基本方法在jdk1.4之后就不用了,取而代之的是内存映射文件方式(nio包),也就是把文件映射到内存后再操作,省去了频繁磁盘IO,对使用者来说比较友好,而且更高效!所以在这里采用RandomAccessFile对文件操作。
以下是代码演示:`
// 文件的分片
@Test
@SneakyThrows
public void shardingFile() {
// 要分片的文件
String filePath = "D:\\repository.zip";
File sourceFile = new File(filePath);
// 分片到的文件夹
String targetPath = "D:\\file\\repository2\\";
File chunkFolder = new File(targetPath);
if (!chunkFolder.exists()) {
chunkFolder.mkdirs();
}
// 分块大小(10MB)
long chunkSize = 1024 * 1024 * 10;
// 分块数量
long chunkNum = (long) Math.ceil(sourceFile.length() * 1.0 / chunkSize);
if (chunkNum <= 0) {
chunkNum = 1;
}
// 缓冲区大小
byte[] b = new byte[1024];
RandomAccessFile raf_read = new RandomAccessFile(sourceFile, "r");
long startTime = System.currentTimeMillis();
for (int i = 0; i < chunkNum; i++) {
// 创建分片文件
File file = new File(targetPath + i);
boolean newFile = file.createNewFile();
if (newFile) {
// 向分块文件中写数据
RandomAccessFile raf_write = new RandomAccessFile(file, "rw");
int len = -1;
while ((len = raf_read.read(b)) != -1) {
raf_write.write(b, 0, len);
if (file.length() > chunkSize) {
break;
}
}
raf_write.close();
}
}
raf_read.close();
long endTime = System.currentTimeMillis();
System.out.println("分片消耗的时间为:" + (endTime - startTime) / 1000 + "秒");
}
// 文件的合并
@Test
@SneakyThrows
public void mergeFile() {
// 分片文件夹
String targetPath = "D:\\file\\repository2\\";
File chunkFolder = new File(targetPath);
// 合并到的文件
String filePath = "D:\\file\\repository.zip";
File mergeFile = new File(filePath);
if (mergeFile.exists()) {
mergeFile.delete();
}
// 创建新的合并文件
mergeFile.createNewFile();
RandomAccessFile raf_write = new RandomAccessFile(mergeFile, "rw");
// 指针指向文件顶端
raf_write.seek(0);
// 缓冲区
byte[] b = new byte[1024];
// 分块列表
File[] filesArray = chunkFolder.listFiles();
long startTime = System.currentTimeMillis();
// 转为集合
List<File> fileList = new ArrayList<>(Arrays.asList(filesArray));
// 合并需要从小到大排序
fileList.sort(new Comparator<File>() {
@Override
public int compare(File o1, File o2) {
if (Integer.parseInt(o1.getName()) < Integer.parseInt(o2.getName())) {
return -1;
}
return 1;
}
});
// 合并文件
for (File chunkFile : fileList) {
RandomAccessFile raf_read = new RandomAccessFile(chunkFile, "rw");
int len = -1;
while ((len = raf_read.read(b)) != -1) {
raf_write.write(b, 0, len);
}
raf_read.close();
}
raf_write.close();
// 删除分片文件夹
FileUtils.deleteDirectory(chunkFolder);
long endTime = System.currentTimeMillis();
System.out.println("合并的消耗的时间为:" + (endTime - startTime) / 1000 + "秒");
}
转载自:https://blog.csdn.net/FeiXiaoKe/article/details/110998446