java io flush_深入理解Java IO的flush

java的io是一个大知识点,

如果把它的知识点拆开来说的话估计能说一个星期,关于io的体系可以看看下面这张图,

4b6d8be021de014a18dd06f1c73ffd03.png

接下来我们从一段代码开始聊吧,先看看下面这段代码

public class test {

public static void main(string[] args) throws exception {

file file = new file("text.txt");

if(!file.exists()) {

file.createnewfile();

}

fileoutputstream fos = new fileoutputstream(file);

bufferedoutputstream bos = new bufferedoutputstream(fos);

byte[] b = new byte[1024];

bos.write(b);

bos.flush();

}

}

代码中构造了一个缓冲流,然后往流里写入一个kb长度的数据,最后调用 flush()方法。

这是很简单的一段代码,最终的输出结果是会生成一个 1kb的 text.text文件。

但如果我们把最后一行注释掉的话

//bos.flush();

最终生成的 text.text大小会变成0.

这个结果是很显然的,不过如果我们把 flush()换成 close()的话,结果是不是还会是 0呢?

关于 flush

flush()这个东西,其实在很久以前的网络传输中就有了

那个时候为了效率,服务器和客户端传输数据的时候不会每产生一段数据就传一段数据

而是会建一个缓冲区,在缓冲区满之后再往客户端传输数据

4d639d1b894ac861f0eca873ca80703f.png

有时候会有这样的问题,当数据不足以填充缓冲区,而又需要往客户端传数据,为了解决这个问题,就有了 flush的概念,将缓冲区的数据强迫发送。

回到上面的问题,如果把 flush换成 close是否可行呢

答案是可以的。

如果看源码就知道 bufferedoutputstream的继承关系

public class bufferoutputstream extends filteroutputstream

bufferedoutputstream没有实现 close()方法,所以会直接调用 filteroutputstream的 close(),而 filteroutputstream的 close()方法会调用 flush()来输出缓冲区数据。

实际开发中关于io操作的,都强调最后要调用 close()方法,上面的例子就是其中一个原因了。

希望与广大网友互动??

点此进行留言吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值