SequenceInputStream:表示其他输入流的逻辑串联,对多个流进行合并。
它从输入流的有序集合开始,并从第一个输入流开始读取,直到到达文件末尾,接着从第二个输入流读取,依次类推,直到到达包含的最后一个输入流的文件末尾为止。
SequenceInputStream(Enumeration<? extends InputStream> e):通过记住参数来初始化新创建的SequenceInputStream,该参数必须是生成运行时类型为 InputStream 对象的 Enumeration 型参数。
案例:合并文件
import java.io.*;
import java.util.*;
class SequenceDemo{
public static void main(String[] args)throws IOException{
Vector<FileInputStream> v=new Vector<FileInputStream>();
v.add(new FileInputStream("f:\\1.txt"));
v.add(new FileInputStream("f:\\2.txt"));
v.add(new FileInputStream("f:\\3.txt"));
// 把多个文件放入一个Enumeration集合中
Enumeration<FileInputStream> en=v.elements();
// 读取Enumeration集合中多个文件内容
SequenceInputStream sis=new SequenceInputStream(en);
// 把多个文件内容写入一个新的文件当中
FileOutputStream fos=new FileOutputStream("f:\\4.txt");
byte[] buf=new byte[1024];
int len=0;
while((len=sis.read(buf))!=-1){
fos.write(buf,0,len);
}
fos.close();
sis.close();
}
}
案例:分割、合并文件
import java.io.*;
import java.util.*;
class SplitFile{
public static void main(String[] args)throws IOException{
// splitFile(); // 分割文件
merge(); // 合并文件
}
// 合并文件
public static void merge()throws IOException{
ArrayList<FileInputStream> a1=new ArrayList<FileInputStream>();
for(int x=1;x<=2;x++){
a1.add(new FileInputStream("f:\\splitfiles\\"+x+".part"));
}
final Iterator<FileInputStream> it=a1.iterator();
Enumeration<FileInputStream> en=new Enumeration<FileInputStream>(){
// 提高效率,使用了ArrayList集合,需要复写Enumeration遍历元素方法
public boolean hasMoreElements(){
return it.hasNext();
}
public FileInputStream nextElement(){
return it.next();
}
};
SequenceInputStream sis=new SequenceInputStream(en);
FileOutputStream fos=new FileOutputStream("f:\\splitfiles\\0.jpg");
byte[] buf=new byte[1024];
int len=0;
while((len=sis.read(buf))!=-1){
fos.write(buf,0,len);
}
fos.close();
sis.close();
}
// 分割文件
public static void splitFile()throws IOException{
FileInputStream fis=new FileInputStream("f:\\1.jpg");
FileOutputStream fos=null;
byte[] buf=new byte[1024*50];
int len=0;
int count=1;
while((len=fis.read(buf))!=-1){
fos=new FileOutputStream("f:\\splitfiles\\"+(count++)+".part");
fos.write(buf,0,len);
fos.close();
}
fis.close();
}
}