最近在學習io流,發(fā)現(xiàn)每次都會出現(xiàn)flush()函數(shù),查了一下其作用,起作用主要如下
//——————–flush()的作用————————–
籠統(tǒng)且錯誤的回答:
緩沖區(qū)中的數(shù)據(jù)保存直到緩沖區(qū)滿后才寫出,也可以使用flush方法將緩沖區(qū)中的數(shù)據(jù)強制寫出或使用close()方法關(guān)閉流,關(guān)閉流之前,緩沖輸出流將緩沖區(qū)數(shù)據(jù)一次性寫出。flash()和close()都使數(shù)據(jù)強制寫出,所以兩種結(jié)果是一樣的,如果都不寫的話,會發(fā)現(xiàn)不能成功寫出
針對上述回答,給出了精準的回答
FileOutPutStream繼承outputStream,并不提供flush()方法的重寫所以無論內(nèi)容多少write都會將二進制流直接傳遞給底層操作系統(tǒng)的I/O,flush無效果而Buffered系列的輸入輸出流函數(shù)單從Buffered這個單詞就可以看出他們是使用緩沖區(qū)的,應用程序每次IO都要和設(shè)備進行通信,效率很低,因此緩沖區(qū)為了提高效率,當寫入設(shè)備時,先寫入緩沖區(qū),等到緩沖區(qū)有足夠多的數(shù)據(jù)時,就整體寫入設(shè)備
使用BufferedXXXStream。默認緩沖區(qū)大小是8K。讀的時候會一直填滿緩沖區(qū)(或者文件讀取完畢),寫的時候也是等緩沖區(qū)滿了之后(或者執(zhí)行flush操作)才將內(nèi)容送入內(nèi)核緩沖區(qū)。效率高的原因就是避免了每讀一個字節(jié)都要陷入操作系統(tǒng)內(nèi)核(這是個耗時的操作)。具體代碼,題主自己查API吧。
再附上來自百度知道的一段問題回答。
flush()意思是把緩沖區(qū)的內(nèi)容強制的寫出。 因為操作系統(tǒng)的某些機制,為了防止一直不停地磁盤讀寫,所以有了延遲寫入的概念,(注意不要和frush()刷新混淆了),主要用在IO中,即清空緩沖區(qū)數(shù)據(jù),一般在讀寫流(stream)的時候,數(shù)據(jù)是先被讀到了內(nèi)存中,再把數(shù)據(jù)寫到文件中,當你數(shù)據(jù)讀完的時候不代表你的數(shù)據(jù)已經(jīng)寫完了,因為還有一部分有可能會留在內(nèi)存這個緩沖區(qū)中。這時候如果你調(diào)用了close()方法關(guān)閉了讀寫流,那么這部分數(shù)據(jù)就會丟失,所以應該在關(guān)閉讀寫流之前先flush()。。
在網(wǎng)絡(luò)web服務器上也是,為了防止寫一個字節(jié)就發(fā)送一個消息,所以有緩沖區(qū)的概念,比如64K的內(nèi)存區(qū)域,緩沖區(qū)寫滿了再一次性寫入磁盤之中(或者發(fā)送給客戶端瀏覽器)。
flush方法一般是程序?qū)懭胪瓿蓵r執(zhí)行。隨后跟著close方法。例如:
1
2
3
4
5
|
// 取得輸出流。當然,看具體環(huán)境。 PrintWriter out = Util.getWriter(); out.println( "輸出一些信息,可能很多" ); out.flush(); out.close(); |
簡單來說,flush()方法是輸出儲存在內(nèi)存中全部的內(nèi)容(批量輸出)。 常用比如FileWriter類中就是一個典型,除了可以使用flush輸出,最后調(diào)用close方法也會批量輸出。
1
2
3
4
5
6
7
8
9
|
import java.io.FileWriter; import java.io.IOException; public class A04 { public static void main(String args[]) { FileWriter fw; try { fw = new FileWriter( "C:\\try.txt" ); fw.write( "Hello" ); //fw.close(); //這句話不加,無法寫入文件,文件空白! System.out.println("OK"); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } |
總結(jié)
以上就是本文關(guān)于Java語言中flush函數(shù)作用及使用方法詳解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
原文鏈接:http://blog.csdn.net/aa8568849/article/details/52974619