十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
最近在學(xué)習(xí)io流,發(fā)現(xiàn)每次都會(huì)出現(xiàn)flush()函數(shù),查了一下其作用,起作用主要如下
//——————–flush()的作用————————–
籠統(tǒng)且錯(cuò)誤的回答:
緩沖區(qū)中的數(shù)據(jù)保存直到緩沖區(qū)滿后才寫出,也可以使用flush方法將緩沖區(qū)中的數(shù)據(jù)強(qiáng)制寫出或使用close()方法關(guān)閉流,關(guān)閉流之前,緩沖輸出流將緩沖區(qū)數(shù)據(jù)一次性寫出。flash()和close()都使數(shù)據(jù)強(qiáng)制寫出,所以兩種結(jié)果是一樣的,如果都不寫的話,會(huì)發(fā)現(xiàn)不能成功寫出
針對(duì)上述回答,給出了精準(zhǔn)的回答
FileOutPutStream繼承outputStream,并不提供flush()方法的重寫所以無(wú)論內(nèi)容多少write都會(huì)將二進(jìn)制流直接傳遞給底層操作系統(tǒng)的I/O,flush無(wú)效果而Buffered系列的輸入輸出流函數(shù)單從Buffered這個(gè)單詞就可以看出他們是使用緩沖區(qū)的,應(yīng)用程序每次IO都要和設(shè)備進(jìn)行通信,效率很低,因此緩沖區(qū)為了提高效率,當(dāng)寫入設(shè)備時(shí),先寫入緩沖區(qū),等到緩沖區(qū)有足夠多的數(shù)據(jù)時(shí),就整體寫入設(shè)備
使用BufferedXXXStream。默認(rèn)緩沖區(qū)大小是8K。讀的時(shí)候會(huì)一直填滿緩沖區(qū)(或者文件讀取完畢),寫的時(shí)候也是等緩沖區(qū)滿了之后(或者執(zhí)行flush操作)才將內(nèi)容送入內(nèi)核緩沖區(qū)。效率高的原因就是避免了每讀一個(gè)字節(jié)都要陷入操作系統(tǒng)內(nèi)核(這是個(gè)耗時(shí)的操作)。具體代碼,題主自己查API吧。
再附上來(lái)自百度知道的一段問(wèn)題回答。
flush()意思是把緩沖區(qū)的內(nèi)容強(qiáng)制的寫出。 因?yàn)椴僮飨到y(tǒng)的某些機(jī)制,為了防止一直不停地磁盤讀寫,所以有了延遲寫入的概念,(注意不要和frush()刷新混淆了),主要用在IO中,即清空緩沖區(qū)數(shù)據(jù),一般在讀寫流(stream)的時(shí)候,數(shù)據(jù)是先被讀到了內(nèi)存中,再把數(shù)據(jù)寫到文件中,當(dāng)你數(shù)據(jù)讀完的時(shí)候不代表你的數(shù)據(jù)已經(jīng)寫完了,因?yàn)檫€有一部分有可能會(huì)留在內(nèi)存這個(gè)緩沖區(qū)中。這時(shí)候如果你調(diào)用了close()方法關(guān)閉了讀寫流,那么這部分?jǐn)?shù)據(jù)就會(huì)丟失,所以應(yīng)該在關(guān)閉讀寫流之前先f(wàn)lush()。。
在網(wǎng)絡(luò)web服務(wù)器上也是,為了防止寫一個(gè)字節(jié)就發(fā)送一個(gè)消息,所以有緩沖區(qū)的概念,比如64K的內(nèi)存區(qū)域,緩沖區(qū)寫滿了再一次性寫入磁盤之中(或者發(fā)送給客戶端瀏覽器)。
flush方法一般是程序?qū)懭胪瓿蓵r(shí)執(zhí)行。隨后跟著close方法。例如:
// 取得輸出流。當(dāng)然,看具體環(huán)境。 PrintWriter out = Util.getWriter(); out.println("輸出一些信息,可能很多"); out.flush(); out.close();