序列流:作用就是将多个读取流合并成一个读取流,实现数据的合并
序列流表示其他输入流的逻辑串联。它从输入流的有序集合开始,并从第一个输入流开始读取,直到文件的末尾,接着从第二个输入流读取,以此类推;这样做,可以方便的操作多个读取流,其实在这个序列流的内部有一个 有序的集合容器,用于存储多个读取流对象
序列流的构造函数参数是枚举,想要获取枚举,需要有Vector集合,因为Vector的elment()方法返回一个指定Collection的枚举。
实现 Enumeration 接口的对象,它生成一系列元素,一次生成一个。连续调用 nextElement
方法将返回一系列的连续元素。
例如,要输出 Vector<E> v 的所有元素,可使用以下方法:
for (Enumeration<E> e = v.elements(); e.hasMoreElements();) System.out.println(e.nextElement());
但是Vector因为同步的原因,效率不高,使用ArrayList,但其没有枚举,所以要自己去实现枚举,只有自己去创建枚举对象。由上面的代码可以看到枚举和迭代器的功能是一样的,所以可以使用迭代替换枚举。
具体代码实现如下:
1 package FileDemo;
2
3 import java.awt.List; 4 import java.io.FileInputStream; 5 import java.io.FileOutputStream; 6 import java.io.IOException; 7 import java.io.SequenceInputStream; 8 import java.util.ArrayList; 9 import java.util.Collections; 10 import java.util.Enumeration; 11 import java.util.Iterator; 12 import java.util.Vector; 13 14 public class SequenceInputStreamDemo { 15 16 /** 17 * @param args 18 * @throws IOException 19 */ 20 public static void main(String[] args) throws IOException { 21 22 ArrayList<FileInputStream> v = new ArrayList<FileInputStream>(); 23 v.add(new FileInputStream("1.txt")); 24 v.add(new FileInputStream("2.txt")); 25 v.add(new FileInputStream("3.txt")); 26 Enumeration<FileInputStream> en = Collections.enumeration(v); 27 // v.add(new FileInputStream("4.txt")); 28 // final Iterator<FileInputStream> it=v.iterator(); 29 /* 30 * Enumeration<FileInputStream> en=new Enumeration<FileInputStream>() { 31 * 32 * @Override public boolean hasMoreElements() { 33 * 34 * return it.hasNext(); } 35 * 36 * @Override public FileInputStream nextElement() { 37 * 38 * return it.next(); } }; 39 */ 40 SequenceInputStream sis = new SequenceInputStream(en); 41 FileOutputStream fos = new FileOutputStream("12345.txt"); 42 byte buf[] = new byte[1024]; 43 int len = 0; 44 while ((len = sis.read(buf)) != -1) { 45 fos.write(buf, 0, len); 46 } 47 fos.close(); 48 sis.close(); 49 } 50 51 }