程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java IO系統總結

Java IO系統總結

編輯:關於JAVA

1 Java IO版本

Java庫的IO分為輸入/輸出兩部分。

早期的Java 1.0版本的輸入系統是InputStream及其子類,輸出系統是OutputStream及其子類。

後來的Java 1.1版本對IO系統進行了重新設計。輸入系統是Reader及其子類,輸出系統是Writer及其子類。

Java1.1之所以要重新設計,主要是為了添加國際化支持(即添加了對16位Unicode碼的支持)。具體表現為Java 1.0的IO系統是字節流,而Java 1.1的IO系統是字符流。

字節流,就是數據流中最小的數據單元是8位的字節。

字符流,就是數據流中最小的數據單元是16位的字符。

字節流在操作的時候,不會用到緩沖;而字符流會用到緩沖。所以,字符流的效率會更高一些。

至於為什麼用到緩沖會效率更高一些呢?那是因為,緩沖本質上是一段內存區域;而文件大多是存儲在硬盤或者Nand Flash上面。讀寫內存的速度比讀寫硬盤或Nand Flash上文件的速度快很多!

目前,文件大多以字節的方式存儲的。所以在開發中,字節流使用較為廣泛。

2 Java 1.0和Java 1.1 的IO類的比較

表01_Java 1.0和Java 1.1的IO基本類對比表

表02_Java 1.0和Java 1.1的IO裝飾器對比表

之所以將Java IO系統分為基本類和裝飾器,是因為基本類主要是將流分為文件、字符串等不同種類,而裝飾器是為了實現“Decorator模式”(參考 “4 Decorator模式”)。

3 Java 1.0 IO系統介紹

因為Java 1.0與Java 1.1的IO系統的原理和使用方法都相似。所以,下面主要對Java 1.0的IO系統進行說明。

3.1輸入流

InputStream是字節輸入流的所有類的超類,它主要包括以下幾個常用的子類。

(01)ByteArrayInputStream

將Byte數組作為字節數組輸入流使用。

(02)StringBufferInputStream

將字符串作為字符串輸入流使用。已過時,不建議使用。

(03)FileInputStream

將文件或FileDescriptor作為文件輸入流使用。創建該輸入流時,傳遞的參數可以是“文件名”(String類型)、“File對象”或“FileDescriptor對象”(即可以是標准輸入流、輸出流、錯誤流的句柄)。

(04)PipedInputString

提供要寫入管道輸出流的所有數據字節。創建該輸入流的時候,可以指定對應的管道輸出輪流;這樣做的話,意味著將對應的管道輸入流連接到了管道輸出流。

(05)FilterInputStream

它直接繼承與InputStream,主要用於實現Decorator模式(這在後面進行說明)。

FilterInputStream主要有兩個派生類“DataInputStream”和“BufferedInputStream”。DataInputStream提供了讀取byte、char、int等基本類型和String的各種接口;BufferedInputStream提供了緩沖功能。

3.2輸出流

OutputStream是字節輸出流的所有類的超類,它主要包括以下幾個常用的子類。

(01)ByteArrayOutputStream

字節數組輸出流,其中的數據被寫入一個 byte 數組。緩沖區會隨著數據的不斷寫入而自動增長。可使用 toByteArray()toString() 獲取數據。

(02)FileOutputStream

文件輸出流是用於將數據寫入 FileFileDescriptor 的輸出流。

 文件是否可用或能否可以被創建取決於基礎平台。特別是某些平台一次只允許一個 FileOutputStream(或其他文件寫入對象)打開文件進行寫入。在這種情況下,如果所涉及的文件已經打開,則此類中的構造方法將失敗。

(03)PipedOutputString

可以將管道輸出流連接到管道輸入流來創建通信管道。管道輸出流是管道的發送端。通常,數據由某個線程寫入 PipedOutputStream 對象,並由其他線程從連接的 PipedInputStream讀取。

 不建議對這兩個對象嘗試使用單個線程,因為這樣可能會造成該線程死鎖。如果某個線程正從連接的管道輸入流中讀取數據字節,但該線程不再處於活動狀態,則該管道被視為處於 毀壞 狀態。

(04)FilterOutputStream

它直接繼承與OutputStream,主要用於實現Decorator模式(這在後面進行說明)。

FilterOutputStream主要有兩個派生類“DataOutputStream”和“BufferedOutputStream”。DataOutputStream提供了寫入byte、char、int等基本類型和String的各種接口;BufferedOutputStream提供了緩沖功能。

4 Decorator模式

Decorator,裝飾模式,又稱為Wrapper。它的主要功能在於動態擴展一個類的功能。

JavaIO系統包括“文件流”、“字符串流”、“字節流”、“緩沖流”等。假如,我們同時需要多種數據流的功能,如輸入流和緩沖流。若采用繼承的方式,數量太可觀了。為了解決這一問題,Decorator模式實現了動態擴展,即在運行的時候動態的給一個類“裝飾”上某些功能。比如:

InputStream input = newBufferedInputStream(new FileInputStream(“test.txt”));

這就是將FileInputStream裝飾成了BufferedInputStream,使它具有了緩沖功能。

5 例子

package com.skywang;

import java.io.*;

public class IOTest{

  publicstatic voidmain(String[] args) throwsIOException {

      try {

           File f=newFile("d:123.txt");

           OutputStream out =

                new BufferedOutputStream(

                    new FileOutputStream(f));

           String str="helloskywang!";

         

          byte[]b=str.getBytes();

          for(int i = 0; i < b.length; i++) {

               out.write(b[i]);

           }

           out.close();

      }catch (FileNotFoundException e){

          e.printStackTrace();

      }catch (SecurityException e){

          e.printStackTrace();

      }

   }

}

查看本欄目

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved