大家好,我是程序员阿药。今天和大家分享的是如何将一个大文件进行分块,再合并分块得到原文件。
第一步:读取原文件,根据分块大小(假设1MB)计算分块的数量。
第二步:根据分块数量循环创建每个分块(分块用数字命名),每创建完成一个分块,从原文件中读取数据并写入分块中。
第三步:通过分块文件目录获得分块列表,根据分块名称进行排序。
第四步:遍历排序后的分块列表,读取每一个分块中的数据并写入新文件中。
第五步:分别计算原文件和合并后的文件的md5值,判断文件是否合并成功。
文件分块代码如下:
public void testChunk() throws IOException {
// 源文件
File sourceFile = new File("D:\\Data\\videos\\test.mp4");
// 分块文件存储路径
String chunkFilePath = "D:\\Data\\chunk\\";
// 分块文件大小(1MB)
int chunkSize = 1024 * 1024;
// 分块文件个数
int chunkNum = (int) Math.ceil(sourceFile.length() * 1.0 / chunkSize);
// 使用流从源文件读数据,向分块文件中写数据
RandomAccessFile raf_r = new RandomAccessFile(sourceFile, "r");
// 缓冲区
byte[] bytes = new byte[1024];
f