[JAVA · 初級]:20.IO流技術

來源:互聯網
上載者:User

[JAVA · 初級]:20.IO流技術
原理

 

在Java程式中,對於資料的輸入/輸出操作以“流” (stream) 方式進行;J2SDK提供了各種各樣的“流”類,用以擷取不同種類的資料;程式中通過標準的方法輸入或輸出資料。

概念

資料來源data source. 提供未經處理資料的原始媒介。常見的:資料庫、檔案、其他程式、記憶體、網路連接、IO裝置。

資料來源就像水箱,流就像水管中流著的水流,程式就是我們最終的使用者。 流是一個抽象、動態概念,是一連串聯續動態資料集合。


 

分類

 

? 流的方向:

輸入資料流:資料來源到程式(InputStream、Reader讀進來)

輸出資料流:程式到目的地(OutPutStream、Writer寫出去)

? 處理資料單元:

位元組流:按照位元組讀取資料(InputStream、OutputStream)

字元流:按照字元讀取資料(Reader、Writer)

? 功能不同:

節點流:可以直接從資料來源或目的地讀寫資料。

處理流:不直接連接到資料來源或目的地,是處理流的流。通過對其他流的處理提高程式的效能。

? 節點流和處理流的關係:

節點流處於io操作的第一線,所有操作必須通過他們進行;處理流可以對其他流進行處理(提高效率或操作靈活性)。

 

體系

 

位元組流

 

? ByteArrayInutStream和ByteArrayOutputStream

? 資料來源或目的地為:位元組數組

?BufferedInputStream和BufferedOutputStream是處理流,通過內部緩衝數組來提高操作流的效率。

? DataInputStream和DataOutputStream提供了可以存取所有Java基礎類型資料(如:int,double 等)的方法。

demo

 

package com.bjsxt.wsl;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.IOException;import java.io.InputStream;public class HelloIn {public static void main(String[] args) throws IOException {//擷取檔案路徑InputStream inputStream = new FileInputStream("D:\\hello.txt");//一般所使用的方式StringBuilder builder = new StringBuilder();byte[] bs = new byte[1024];int num = 0;//開始讀取資料while ((num = inputStream.read(bs)) != -1) {builder.append(new String(bs));}System.out.println(builder);}

 

字元流

? Reader:

用於讀取字元流的抽象類別,資料單位為字元。

? Writer:

寫入字元流的抽象類別。

? BufferReader和BufferWriter

讀取文本一般使用這一對!

處理流

對象的序列化和還原序列化:

ObjectInputStream和ObjectOutputStream,資料來源或目的地是:對象!

列印流:

PrintWriter和PrintStream的輸出操作不會拋出異常,使用者通過檢測錯誤狀態擷取錯誤資訊。

System.out 就是列印流

InputStreamReader和OutputStreamWrite為處理流:用於將位元組流轉化成字元流。

File類

檔案和目錄路徑名的抽象表示形式。一個File對象可以代表一個檔案或目錄,但是不是完全對應的。建立File對象不會對檔案系統產生影響。

業務思想

IO流技術的使用,使得我們的工作更為順暢,無論是從實體儲存體的角度來看待,還是從邏輯思維中來理解,都變得很容易接受。

這裡只是簡單地介紹了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.