【java的 IO流之緩衝流】

來源:互聯網
上載者:User

標籤:

java緩衝流本身不具IO功能,只是在別的流上加上緩衝提高效率,像是為別的流裝上一種封裝。當對檔案或其他目標頻繁讀寫或操作效率低,效能差。這時使用緩衝流能夠更高效的讀寫資訊。因為緩衝流先將資料緩衝起來,然後一起寫入或讀取出來。所以說,緩衝流還是很重要的,在IO操作時記得加上緩衝流提升效能。
       緩衝流分為位元組和字元緩衝流位元組緩衝流為:BufferedInputStream—位元組輸入緩衝流BufferedOutputStream—位元組輸出緩衝流字元緩衝流為:BufferedReader—字元輸入緩衝流BufferedWriter—字元輸出緩衝流下面主要介紹這四種緩衝流的使用。
一.位元組緩衝流1.BufferedOutputStream—位元組輸出緩衝流      BufferedOutputStream類實現緩衝的輸出了,通過設定這種輸出資料流,應用程式就可以將各個位元組寫入底層輸出資料流中,而不必每一個位元組寫入都調用底層系統。該類的建構函式:範例程式碼:
  1. public static void main(String[] args) {         
  2.       try {  
  3.     //建立位元組輸出資料流執行個體  
  4.     OutputStream out=new FileOutputStream("L:\\test.txt");  
  5.     //根據位元組輸出資料流構建位元組緩衝流  
  6.     BufferedOutputStream buf=new BufferedOutputStream(out);  
  7.       
  8.     String data="好好學習,天天向上";  
  9.     buf.write(data.getBytes());//寫入緩衝區  
  10.     buf.flush();//重新整理緩衝區,即把內容寫入  
  11.     //關閉流  
  12.     buf.close();//關閉緩衝流時,也會重新整理一次緩衝區  
  13.     out.close();  
  14.       
  15. } catch (IOException e) {  
  16.     e.printStackTrace();  
  17. }  
  18.     
  19.    }   
複製代碼2.BufferedInputStream—位元組輸入緩衝流       BufferedInputStream為別的輸入資料流添加緩衝功能,在建立BufferedInputStream時會建立一個內部緩衝數組,用於緩衝資料,提高效能。範例程式碼:
  1. public static void main(String[] args) {         
  2.        try {  
  3.         //建立位元組輸入資料流執行個體  
  4.         InputStream in=new FileInputStream("L:\\test.txt");  
  5.         //根據位元組輸入資料流構建位元組緩衝流  
  6.         BufferedInputStream buf=new BufferedInputStream(in);  
  7.           
  8.         byte[]bytes=new byte[1024];  
  9.         //資料讀取  
  10.         int len=-1;  
  11.         StringBuffer  sb=new StringBuffer();  
  12.         while((len=buf.read(bytes))!=-1)  
  13.         {  
  14.             sb.append(new String(bytes,0,len));  
  15.         }  
  16.         System.out.println("內容為:"+sb);  
  17.         //關閉流  
  18.         buf.close();  
  19.         in.close();  
  20.           
  21.           
  22.     } catch (IOException e) {  
  23.         e.printStackTrace();  
  24.     }  
  25.      
  26.     }   
複製代碼運行結果:
<ignore_js_op> 

二.字元緩衝流 1.BufferedWriter—字元輸出緩衝流    將文本寫入字元輸出資料流,緩衝各個字元,從而提供高效的寫入。可以指定緩衝區的大小,一般情況下,預設的緩衝區大小就足夠了。範例程式碼:
  1. public static void main(String[] args) {  
  2.       
  3.     try {  
  4.         Writer w=new FileWriter("L:\\test.txt");  
  5.         //根據字元輸出資料流建立字元緩衝流  
  6.         BufferedWriter buf=new BufferedWriter(w);  
  7.         //寫入資料  
  8.         buf.write("只要功夫深鐵杵磨成針");  
  9.         //重新整理流  
  10.         buf.flush();  
  11.         //關閉流  
  12.         buf.close();  
  13.         w.close();  
  14.     } catch (IOException e) {  
  15.         e.printStackTrace();  
  16.     }  
  17.       
  18.     
  19.    }   
複製代碼運行結果:
<ignore_js_op> 
2.BufferedReader—字元輸入緩衝流         從字元輸入資料流中讀取資訊,緩衝各個字元,從而實現高效讀取。可以指定緩衝區的大小,一般情況下,預設的緩衝區大小就足夠了。預設大小為8192.
範例程式碼:
  1. public static void main(String[] args) {  
  2.           
  3.         try {  
  4.             Reader r=new FileReader("L:\\test.txt");  
  5.             //根據字元輸入資料流建立字元緩衝流  
  6.             BufferedReader buf=new BufferedReader(r);  
  7.               
  8.             char [] data=new char[512];  
  9.             //資料讀取  
  10.             int len=-1;  
  11.             StringBuilder sb=new StringBuilder();  
  12.             while((len=buf.read(data))!=-1)  
  13.             {  
  14.                 sb.append(new String(data,0,len));  
  15.             }  
  16.             System.out.println("內容是: "+sb);  
  17.             //關閉流  
  18.             buf.close();  
  19.             r.close();  
  20.         } catch (IOException e) {  
  21.             e.printStackTrace();  
  22.         }  
  23.           
  24.      
  25.     }   
複製代碼運行結果:
<ignore_js_op>

【java的 IO流之緩衝流】

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.