关于java中输出流flush()方法

原文章地址:

关于java中输出流flush()方法   http://blog.csdn.net/lsx991947534/article/details/45065773

下面原文的内容,我直接转过来了,有点无耻了\(^o^)/~...............,再次向原博主表示道歉和感谢^_^


在java开发中,有时我们会进行流的操作,所以可能会经常遇到这样一段代码

[java]  view plain  copy
  1. out.flush();  
  2. out.close();  
有时我们只是大概看懂这些,却不知道其中的原理性东西,下面就来理解一下:

flush()这个函数是清空的意思,用于清空缓冲区的数据流,进行流的操作时,数据先被读到内存中,然后再用数据写到文件中,那么当你数据读完时,我们如果这时调用close()方法关闭读写流,这时就可能造成数据丢失,为什么呢,因为,读入数据完成时不代表写入数据完成,一部分数据可能会留在缓存区中,为了理解这个问题,我们举一个例子:

比如,在农村,几乎每家都有抽水机,抽水机的作用是什么呢,就是把水井里的水抽到水缸中,这时我们就会用水管连接抽水机和水缸(水管就好比是缓冲区),当我们想把水井中的水都抽到水缸中时,我们就让抽水机工作抽水,如果我们发现水井里的水刚好抽完时,我们就会关掉抽水机的开关停止抽水,那么这时,管道里就会遗留一部分水,抽水就是读数据,水缸进水就是写数据,水管充当缓存区的角色,不知道这样是不是具象化了呢

那么这样一来我们如果中途调用close()方法,输出区也还是有数据的,就像水缸里有水,只是在缓冲区遗留了一部分,这时如果我们先调用flush()方法,就会强制把数据输出,缓存区就清空了,最后再关闭读写流调用close()就完成了。

[java]  view plain  copy
  1.  public class PrintWriter extends Writer {  
  2.     protected Writer out;  
  3. /** Checks to make sure that the stream has not been closed */  
  4.     private void ensureOpen() throws IOException {  
  5.         if (out == null)  
  6.             throw new IOException("Stream closed");  
  7.     }  
  8.   
  9.     /** 
  10.      * Flushes the stream. 
  11.      * @see #checkError() 
  12.      */  
  13.     public void flush() {  
  14.         try {  
  15.             synchronized (lock) {  
  16.                 ensureOpen();  
  17.                 out.flush();  
  18.             }  
  19.         }  
  20.         catch (IOException x) {  
  21.             trouble = true;  
  22.         }  
  23.     }  
  24.   
  25. }  
这是JDK中PrintWriter类提供的flush方法,如上面注释所说,ensureOpen()方法是用于确保该流没有被关闭,如果没有关闭则执行flush方法中的out.flush();

这样列举是不是对PrintWriter中的方法有有所理解了呢。那么问题又来了,我们平时用的flush()和这里的flush()是不是一样的呢?这个就先思考一下


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值