程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> Java 1.0和Java 1.1 的IO類的比較

Java 1.0和Java 1.1 的IO類的比較

編輯:JAVA編程入門知識

Java 1.0 IO系統介紹
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
文件輸出流是用於將數據寫入 File 或 FileDescriptor 的輸出流。
  文件是否可用或能否可以被創建取決於基礎平台。特別是某些平台一次只允許一個 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 JAVA IO例子
代碼如下:

package com.skywang;

import java.io.*;
public class IOTest{
    publicstaticvoidmain(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