SequenceInputStream 合并流与切割流

将多个流合并成一个流

SequenceInputStream(Enumeration<? extends InputStream> e)
SequenceInputStream(InputStream s1, InputStream s2)

例:将多个文件合并到一个流中,再写到一个文件中:

Vector<FileInputStream> v = new Vector<FileInputStream>();

v.add(new FileInputStream("c:\\1.txt"));
v.add(new FileInputStream("c:\\2.txt"));
v.add(new FileInputStream("c:\\3.txt"));

Enumeration<FileInputStream> en = v.elements();

SequenceInputStream sis = new SequenceInputStream(en);

FileOutputStream fos = new FileOutputStream("c:\\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();

合并文件

ArrayList<FileInputStream> aList = new ArrayList<FileInputStream>();// 为什么要用list,因为Vector已经过时了。

for (int x = 1; x <= 4; x++)
{
aList.add(new FileInputStream("d:\\tmp\\" + x + ".part"));// 循环的将d:\\tmp\\下的part文件加入aList中
}

final Iterator<FileInputStream> it = aList.iterator();

Enumeration<FileInputStream> en = new Enumeration<FileInputStream>()
{

@Override
public FileInputStream nextElement()
{

// TODO Auto-generated method stub
return it.next();
}

@Override
public boolean hasMoreElements()
{

// TODO Auto-generated method stub
return it.hasNext();
}
};

SequenceInputStream sis = new SequenceInputStream(en);
FileOutputStream fos = new FileOutputStream("d:\\tmp\\aa.exe");
byte[] buf = new byte[1024 * 1024];
int len = 0;
while ((len = sis.read(buf)) != -1)
{
fos.write(buf, 0, len);
}
fos.close();
sis.close();

切割文件

FileInputStream fis = new FileInputStream("d:\\tmp\\plsqldev.exe");
FileOutputStream fos = null;
byte[] bytes = new byte[1024 * 1024 * 3];
int len = 0;
int count = 1;
while ((len = fis.read(bytes)) != -1)
{

fos = new FileOutputStream("d:\\tmp\\" + (count++) + ".part");
fos.write(bytes, 0, len);
}

fos.close();
fis.close();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值