文件流read()、write()

本文解释了在Java中使用InputStream和FileOutputStream进行文件操作时,如何正确使用缓存byte[]数组以避免数据溢出问题,以及read()和write()方法的使用策略,强调了EOF标志的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

InputStream inputStream = media.getStreamData()
FileOutputStream fos = new FileOutputStream ()
byte[] b = new byte[1024];
int n = 0;
while ((n = inputStream.read(buffer)) != -1) { fos.write(b,0,n);
}
b数组用来缓存,通过inputStream读入数据。
b数组大小决定了一次传入缓存的字节数量,while循环时一次传入的可读长度。
如果write只使用write(b),而不用长度n来限制,会由于b的初始值大小造成最终的输出流有问题。
比如写出的文件多出一行;
比如读取一个2049字节大小的文件时,初始值为byte[2048],第一次input读取时b被填满2048个字节,但下次读取时还剩2049-2048=1位字节未读取,所以b缓存中仅是第一位内容更新,其余位置还是被上次读取的数据占位。
因此fos第二次写入的大小还是2048,这样最终写入文件的大小就是2048*2。
上文提到read(b)便是一次读1024字节的数
read()表示一次读一个字节,即可读字节数为b.length, n表示每次循环能读到的下一段数据长度,fos.write(b,0,n)则是根据读到的b数据写入output指向的文件。
while循环中的-1则是EOF(End Of File)结束标志,表示文件读取结束。因为ASCII代码值的范围是0~255,不可能出现-1。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值