深入理解Java IO的flush
Java的IO是一個大知識點,
如果把它的知識點拆開來說的話估計能說一個星期,關于IO的體系可以看看下面這張圖,

接下來我們從一段代碼開始聊吧,先看看下面這段代碼
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長度的數(shù)據(jù),最后調用 flush()方法。
這是很簡單的一段代碼,最終的輸出結果是會生成一個 1KB的 text.text文件。
但如果我們把最后一行注釋掉的話
//bos.flush();
最終生成的 text.text大小會變成0.
這個結果是很顯然的,不過如果我們把 flush()換成 close()的話,結果是不是還會是 0呢?
關于 flush
flush()這個東西,其實在很久以前的網(wǎng)絡傳輸中就有了
那個時候為了效率,服務器和客戶端傳輸數(shù)據(jù)的時候不會每產(chǎn)生一段數(shù)據(jù)就傳一段數(shù)據(jù)
而是會建一個緩沖區(qū),在緩沖區(qū)滿之后再往客戶端傳輸數(shù)據(jù)

有時候會有這樣的問題,當數(shù)據(jù)不足以填充緩沖區(qū),而又需要往客戶端傳數(shù)據(jù),為了解決這個問題,就有了 flush的概念,將緩沖區(qū)的數(shù)據(jù)強迫發(fā)送。
回到上面的問題,如果把 flush換成 close是否可行呢
答案是可以的。
如果看源碼就知道 BufferedOutputStream的繼承關系
public class BufferOutputStream extends FilterOutputStream
BufferedOutputStream沒有實現(xiàn) close()方法,所以會直接調用 FilterOutputStream的 close(),而 FilterOutputStream的 close()方法會調用 flush()來輸出緩沖區(qū)數(shù)據(jù)。
實際開發(fā)中關于IO操作的,都強調最后要調用 close()方法,上面的例子就是其中一個原因了。
相關文章
java實用型-高并發(fā)下RestTemplate的正確使用說明
這篇文章主要介紹了java實用型-高并發(fā)下RestTemplate的正確使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10
SpringBoot利用dag加速Spring beans初始化的方法示例
本文介紹了利用DAG加速SpringBoot中Spring beans初始化,先解釋了DAG 概念及特性,包括節(jié)點入度出度、拓撲排序等,接著闡述加速Spring Bean初始化的實現(xiàn)思路,如識別依賴關系構建DAG、拓撲排序、并行初始化Bean及與Spring集成,還展示了相關代碼工程、測試結果及引用2024-12-12

