/**
* 将分割好的文件重新链接
* @param filePath 被分割好的其中之一文件路径,默认其他块与其在同一目录下
* @param howManyParts 一共有多少块
* @return 成功返回True,出错则返回False
*/
public static boolean glue(Path filePath, int howManyParts){
return true;
}
}
接下来实现单线程的分割方法: 用图解的话应该是这样:
![](https://user-gold-cdn.xitu.io/2018/11/20/16730faee905f6a8?imageView2/0/w/1280/h/960/format/webp/ignore-error/1)
代码实现: 进入函数首先判断文件是否存在:
if (!Files.exists(filePath)){
return false;
}
接下来判断每块大小是否使用默认值:
if(filePieceSize == -1){
filePieceSize = 1024*1024*64;
}
将路径转换为文件对象,再计算将分割多少块:
File file = filePath.toFile();
int howManyParts = (int) Math.ceil(file.length() / (double)filePieceSize);
初始化输入输出流,出错输出错误信息,返回false,获得当前目录:
DataInputStream fileReader = null;
try {
fileReader = new DataInputStream(new FileInputStream(file));
} catch (FileNotFoundException e) {
e.printStackTrace();
System.out.println("文件找不到!");
return false;
}
DataOutputStream fileWriter;
Path dir = filePath.getParent();
接下来读取文件,并且分别输出到各个part文件中:
int readLength = -1;
long total = 0;
try {
for (int i = 1; i <= howManyParts ; i++){
//新建文件part i
Path temp = Files.createFile(dir.resolve(filePath.getFileName() + ".part" + i));
//搭建输出流
fileWriter = new DataOutputStream(new FileOutputStream(temp.toFile()));
//读取文件并输出
while ( (readLength = fileReader.read(buffer)) != -1){
fileWriter.write(buffer,0,readLength);
fileWriter.flush();
total += readLength;
if (total == filePieceSize){
total = 0;
break;
}
}
//part i的文件已经输出完毕,关闭流
fileWriter.close();
}
//读取完毕,关闭输入流
fileReader.close();
} catch (IOException e) {
e.printStackTrace();
System.out.println("IO错误!");
return false;
}
该函数已经实现完毕,接下来测试(由于电影Fury有14G。。太大了。。还是换个吧):
![](https://user-gold-cdn.xitu.io/2018/11/20/16730faeea03cc54?imageView2/0/w/1280/h/960/format/webp/ignore-error/1)
我是大哥大第5集,有729M,大概能分个12个part吧。
public static void main(String[] args) throws IOException {
double before = System.currentTimeMillis();
Path bigboss = Paths.get("D:\\Video\\我是大哥大\\我是大哥大.Kyou.kara.Ore.wa.Ep05.Chi_Jap.HDTVrip.1280X720.mp4");
FileSlice.slice(bigboss,-1);
double after = System.currentTimeMillis();
System.out.println("分割文件我是大哥大.Kyou.kara.Ore.wa.Ep05.Chi_Jap.HDTVrip.1280X720.mp4," + Files.size(bigboss) + "字节,总用时" + (after - before) + "ms" );
}
运行结果:
分割文件我是大哥大.Kyou.kara.Ore.wa.Ep05.Chi_Jap.HDTVrip.1280X720.mp4,765321889字节,总用时16335.0ms
![](https://user-gold-cdn.xitu.io/2018/11/20/16730faeea2cd9f6?imageView2/0/w/1280/h/960/format/webp/ignore-error/1)
速度还是挺慢的。。 下次还是换成多线程来实现,再来测试下速度。在单线程情况下一个普通的40分钟日剧都要15-30s左右,要是mkv格式的电影都要好久了。。不过其实极限应该不在CPU中执行的速度,而是在硬盘IO中,如果是普通硬盘那么就算是多线程也应该提速不了多少。。
### 文件拼接
这个就很简单了,和分割相反就OK。 直接上完整代码:
public static boolean glue(Path filePath, int howManyParts){
if (!Files.exists(filePath)){
return false;
}
//获取原始文件名
String filename = getOriginalFileName(filePath.getFileName().toString());
if (filename == null){
System.out.println("传入part文件名解析出错!");
return false;
}
//初始化缓冲区
最后
由于篇幅有限,这里就不一一罗列了,20道常见面试题(含答案)+21条MySQL性能调优经验小编已整理成Word文档或PDF文档,点击这里免费下载
还有更多面试复习笔记分享如下
return false;
}
//初始化缓冲区
最后
由于篇幅有限,这里就不一一罗列了,20道常见面试题(含答案)+21条MySQL性能调优经验小编已整理成Word文档或PDF文档,点击这里免费下载
[外链图片转存中…(img-Vh6TjaRv-1628490609171)]
还有更多面试复习笔记分享如下
[外链图片转存中…(img-w4dN8qwb-1628490609173)]