需求:
1、将指定文件分割成指定大小的碎片文件
2、将碎片文件合并成完整的文件
分析:
1、将指定文件分割成指定大小的碎片文件
源:一个文件 目的:多个文件
根据指定碎片大小创建缓冲区数组,用来存储各指定长度的分片文件。循环创建字节流输出流,关联各个碎片文件。
2、将碎片文件合并成完整的文件
源:多个文件 目的:一个文件
创建多个字节输入流关联碎片文件,合并成序列流,可以直接是Vector集合,来获取Enumeration对象,但是效率较低。
也可以使用ArrayList集合,通过迭代器获取Enumeration对象。
代码:
/*
* 文件的切割和合并
* 1、切割
* 源:一个文件
* 目的:多个文件
* 创建缓冲区数组,循环读取被切割文件,存到缓冲区数组中,然后写到新的文件中
* 2、合并
* 源:多个文件
* 目的:一个文件
* 将多个文件流合并成以序列流,然后读取到输出流中。写到目标文件中
* */
import java.io.*;
import java.util.*;
class SandM
{
//切割文件
//指定切割大小
public static void splitFile(File f, int size)throws IOException
{
//创建字节输入流对象,与被切割文件相关联
FileInputStream fis = new FileInputStream(f);
//创建字节写入流,与目标文件相关联
FileOutputStream fos