今天主要学习了序列流
序列流,也称为合并流——SequenceInputStream:
特点:可以将多个读取流合并成一个流。这样操作起来很方便。
原理:其实就是将每一个读取流对象存储到一个集合中。最后一个流对象结尾作为这个流的结尾。
两个构造函数:
1,SequenceInputStream(InputStream in1,InputStream in2)
可以将两个读取流合并成一个流。
2,SequenceInputStream(Enumeration<? extends InputStream> en)
可以将枚举中的多个流合并成一个流。
作用:可以用于多个数据的合并。
//将两个文件拼接为一个流进行依次读取 import java.io.*;
public class DataIODemo1 { public static void main(String[] args) throws IOException { FileInputStream fis1 = new FileInputStream("res/a.txt"); FileInputStream fis2 = new FileInputStream("res/number.txt");
SequenceInputStream sis = new SequenceInputStream(fis1, fis2);
int ch; while((ch = sis.read()) != -1){ System.out.print((char)ch); }
sis.close(); fis1.close(); fis2.close(); } }
|
注意:因为Enumeration是Vector中特有的取出方式。而Vector被ArrayList取代。
所以要使用ArrayList集合效率更高一些。那么如何获取Enumeration呢?
ArrayList<FileInputStream > al = new ArrayList<FileInputStream>();
for(int x=1; x<4; x++) al.add(new FileInputStream(x+".txt"));
//返回按适当顺序在列表的元素上进行迭代的迭代器。 final Iterator<FileInputStream> it = al.iterator(); Enumeration<FileInputStream> en = new Enumeration<FileInputStream>() { public boolean hasMoreElements() { return it.hasNext(); } public FileInputStream nextElement() { return it.next(); } };
//多个流就变成了一个流,这就是数据源。 SequenceInputStream sis = new SequenceInputStream(en);
//创建数据目的。 FileOutputStream fos = new FileOutputStream("4.txt");
byte[] buf = new byte[1024*4];
int len = 0;
while((len=sis.read(buf))!=-1) { fos.write(buf,0,len); }
fos.close(); sis.close();
//如果要一个对文件数据切割。
一个读取对应多了输出。 FileInputStream fis = new FileInputStream("1.mp3");
FileOutputStream fos = null;
byte[] buf = new byte[1024*1024];//是一个1m的缓冲区。
int len = 0; int count = 1;
while((len=fis.read(buf))!=-1) { fos = new FileOutputStream((count++)+".part"); fos.write(buf,0,len);
fos.close(); } fis.close();
//这样就是将1.mp3文件切割成多个碎片文件。 |
想要合并使用SequenceInputStream即可。
对于切割后,合并是需要的一些源文件的信息。
可以通过配置文件进行存储。该配置可以通过键=值的形式存在。
然后通过Properties对象进行数据的加载和获取。