运用Java编写代码将一个大文件切割成指定大小的小文件 思路: 对已知文件进行切割操作 – 得到多个碎片文件 使用: 1、 1个字节输入流 – 读取已知文件中的数据 2、 多个字节输出流
运用Java编写代码将一个大文件切割成指定大小的小文件
思路:
对已知文件进行切割操作 –> 得到多个碎片文件
使用:
1、 1个字节输入流 –> 读取已知文件中的数据
2、 多个字节输出流 –> 生成多个碎片文件
思路补充:
创建一个指定大小的byte数组,将大文件读取到byte数组中,读满一次将byte数组写入一个新的小文件中,如此循环直到将大文件读取完毕
注意:此时最后一个小文件可能不足规定的内存大小,在从大文件读取最后一个byte数组时,可能还没读满byte数组,大文件就读取完毕了,所以只能将最后的未满足规定内存大小byte数组写入最后一个文件中;
具体代码如下:
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; public class CutDemo { public static void main(String[] args) { //调用cutFile()函数 传人参数分别为 (原大文件,切割后存放的小文件的路径,切割规定的内存大小) cutFile("D:\\java\\cut\\ForrestGump.avi", "D:\\java\\cuts",1024 * 1024 * 20); } private static void cutFile(String src, String endsrc, int num) { FileInputStream fis = null; File file = null; try { fis = new FileInputStream(src); file = new File(src); //创建规定大小的byte数组 byte[] b = new byte[num]; int len = 0; //name为以后的小文件命名做准备 int name = 1; //遍历将大文件读入byte数组中,当byte数组读满后写入对应的小文件中 while ((len = fis.read(b)) != -1) { //分别找到原大文件的文件名和文件类型,为下面的小文件命名做准备 String name2 = file.getName(); int lastIndexOf = name2.lastIndexOf("."); String substring = name2.substring(0, lastIndexOf); String substring2 = name2.substring(lastIndexOf, name2.length()); FileOutputStream fos = new FileOutputStream(endsrc + "\\\\"+ substring + "-" + name + substring2); //将byte数组写入对应的小文件中 fos.write(b, 0, len); //结束资源 fos.close(); name++; } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { try { if (fis != null) { //结束资源 fis.close(); } } catch (IOException e) { e.printStackTrace(); } } } }
对应路径截图
原大文件路径截图:
切割后的小文件执行代码前路径截图:
切割后的小文件执行代码后路径截图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。