Java实现文件切割拼接

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

最近看的BradPitt的《狂怒》

首先:对文件进行分割需要确定每一部分的大小,假设上面的_Fury.mkv_文件大小为280M,分割每一块设置默认大小为64M,所以:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

对于最后一块,一般小于等于设定好的每块默认大小。 每块大小设置好了,接下来,就需要将文件的路径获取,代码中搭建输入流,将文件读入内存缓冲区中,再搭建输出流,将缓冲区输出到新的分割文件中。 再接下来实现就很简单了。 新建一个_FileSlice_类:有切割方法,拼接方法。

public class FileSlice {

/**

  • 分割文件

  • @param filePath 文件路径

  • @param filePieceSize 文件每块大小,单位为字节,为-1则默认为每块64M

  • @return 成功返回True,出错则返回False

*/

public static boolean slice(Path filePath, int filePieceSize){

return true;

}

/**

  • 将分割好的文件重新链接

  • @param filePath 被分割好的其中之一文件路径,默认其他块与其在同一目录下

  • @param howManyParts 一共有多少块

  • @return 成功返回True,出错则返回False

*/

public static boolean glue(Path filePath, int howManyParts){

return true;

}

}

接下来实现单线程的分割方法: 用图解的话应该是这样:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

代码实现: 进入函数首先判断文件是否存在:

if (!Files.exists(filePath)){

return false;

}

接下来判断每块大小是否使用默认值:

if(filePieceSize == -1){

filePieceSize = 1024102464;

}

将路径转换为文件对象,再计算将分割多少块:

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。。太大了。。还是换个吧):

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

我是大哥大第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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

速度还是挺慢的。。 下次还是换成多线程来实现,再来测试下速度。在单线程情况下一个普通的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());

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

俗话说,好学者临池学书,不过网络时代,对于大多数的我们来说,我倒是觉得学习意识的觉醒很重要,这是开始学习的转折点,比如看到对自己方向发展有用的信息,先收藏一波是一波,比如如果你觉得我这篇文章ok,先点赞收藏一波。这样,等真的沉下心来学习,不至于被找资料分散了心神。慢慢来,先从点赞收藏做起,加油吧!

另外,给大家安排了一波学习面试资料:

image

image

以上就是本文的全部内容,希望对大家的面试有所帮助,祝大家早日升职加薪迎娶白富美走上人生巅峰!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
章ok,先点赞收藏一波。这样,等真的沉下心来学习,不至于被找资料分散了心神。慢慢来,先从点赞收藏做起,加油吧!

另外,给大家安排了一波学习面试资料:

[外链图片转存中…(img-gkf8yatm-1713139660551)]

[外链图片转存中…(img-OUkylfWT-1713139660551)]

以上就是本文的全部内容,希望对大家的面试有所帮助,祝大家早日升职加薪迎娶白富美走上人生巅峰!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值