java:IO流學習小結

來源:互聯網
上載者:User

        今天剛剛看完Java的io流操作,把主要的脈絡看了一遍,不能保證以後使用時都能得心應手,但是最起碼用到時知道有這麼一個功能可以實現,下面對學習進行一下簡單的總結:

        IO流主要用於硬板、記憶體、鍵盤等處理裝置上得資料操作,根據處理資料的資料類型的不同可以分為:位元組流(抽象基類為InPutStream和OutPutStream)和字元流(抽象基類為Reader和Writer)。根據流向不同,可以分為:輸入資料流和輸出資料流。  其中主要結構可以用下圖來表示:                          

                                   

      

 字元流和位元組流的主要區別:

       1.位元組流讀取的時候,讀到一個位元組就返回一個位元組;  字元流使用了位元組流讀到一個或多個位元組(中文對應的位元組數是兩個,在UTF-8碼錶中是3個位元組)時。先去查指定的編碼錶,將查到的字元返回。

       2.位元組流可以處理所有類型資料,如:圖片,MP3,AVI視頻檔案,而字元流只能處理字元資料。只要是處理純文字資料,就要優先考慮使用字元流,除此之外都用位元組流。

     

 IO流主要可以分為節點流和處理流兩大類。

     

 一、節點流類型

       該類型可以從或者向一個特定的地點或者節點讀寫資料。主要類型如下:

類型 字元流 位元組流
File(檔案) FileReader FileWriter FileInputStream FileOutputSream
Memory Array CharArrayReader CharArrayWriter ByteArrayInputStream ByteArrayOutputSream
Memory String StringReader StringWriter    -
Pipe(管道) PipedReader PipedWriter PipedInputSream PipedOutputSream

         二、處理流類型         該類型是對一個已存在的流的串連和封裝,通過所封裝的流的功能調用實現資料讀寫,處理流的構造方法總是要帶一個其他流對象作為參數,一個流對象進過其他流的多次封裝,叫做流的連結。主要可以分為以下幾種:    1、緩衝流(BufferedInPutStream/BufferedOutPutStream和BufferedWriter/BufferedReader)他可以提高對流的操作效率。                               寫入緩衝區對象:                  [java]  view plain  copy BufferedWriter bufw=new BufferedWriter(new FileWriter("buf.txt"));                     讀取緩衝區對象:                 [java]  view plain  copy BufferedReader bufr=new BufferedReader(new FileReader("buf.txt"));                       該類型的流有一個特有的方法:readLine();一次讀一行,到行標記時,將行標記之前的字元資料作為字串返回,當讀到末尾時,返回null,其原理還是與緩衝區關聯的流對象的read方法,只不過每一次讀取到一個字元,先不進行具體操作,先進行臨時儲存,當讀取到斷行符號標記時,將臨時容器中儲存的資料一次性返回。                                2、轉換流(InputStreamReader/OutputStreamWriter)       該類型時位元組流和字元流之間的橋樑,該流對象中可以對讀取到的位元組資料進行指定編碼的編碼轉換。       建構函式主要有:     [java]  view plain  copy InputStreamReader(InputStream);        //通過建構函式初始化,使用的是本系統預設的編碼錶GBK。    InputStreamWriter(InputStream,String charSet);   //通過該建構函式初始化,可以指定編碼錶。    OutputStreamWriter(OutputStream);      //通過該建構函式初始化,使用的是本系統預設的編碼錶GBK。    OutputStreamwriter(OutputStream,String charSet);   //通過該建構函式初始化,可以指定編碼錶。           注意:在使用FileReader操作文本資料時,該對象使用的時預設的編碼錶,即                    FileReader fr=new FileReader(“a.txt”);      與     InputStreamReader isr=new InputStreamReader(new FileInputStream("a.txt"));   的意義相同。如果要使用指定表編碼錶時,必須使用轉換流,即如果a.txt中的檔案中的字元資料是通過utf-8的形式編碼,那麼在讀取時,就必須指定編碼錶,那麼轉換流時必須的。即:                    InputStreamReader isr=new InputStreamReader(new FileInputStream("a.txt"),utf-8);            3、資料流(DataInputStream/DataOutputStream)           該資料流可以方便地對一些基本類型資料進行直接的儲存和讀取,不需要再進一步進行轉換,通常只要操作基礎資料型別 (Elementary Data Type)的資料,就需要通過DataStream進行封裝。           構造方法:         [java]  view plain  copy DataInputStreamReader(InputStream);    DataInputStreamWriter(OutputStream);             方法舉例:           [java]  view plain  copy int readInt();//一次讀取四個位元組,並將其轉成int值   writeInt(int);//一次寫入四個位元組,注意和write(int)不同,write(int)只將該整數的最低一個8位寫入,剩餘三個8為丟失   hort readShort();   writeShort(short);   String readUTF();//按照utf-8修改版讀取字元,注意,它只能讀writeUTF()寫入的字元資料。    writeUTF(String);//按照utf-8修改版將字元資料進行儲存,只能通過readUTF讀取。             注意:在使用資料流讀/存資料的時候,需要有一定的順序,即某個類型的資料先寫入就必須先讀出,服從先進先出的原則。     四、列印流(PrintStream/PrintWriter)        PrintStream是一個位元組列印流,System.out對應的類型就是PrintStream,它的建構函式可以接受三種資料類型的值:1.字串路徑。2.File對象 3.OutputStream        PrintStream是一個字元列印流,它的建構函式可以接受四種類型的值:1.字串路徑。2.File對象 3.OutputStream  4.Writer  對於1、2類型的資料,可以指定編碼錶,也就是字元集,對於3、4類型的資料,可以指定自動重新整理,當該自動重新整理為True時,只有3個方法可以用:println,printf,format。   五、物件流程(ObjectInputStream/ObjectOutputStream)         該類型的流可以把類作為一個整體進行存取,主要方法有:         Object readObject();該方法拋出異常:ClassNotFountException。         void writeObject(Object):被寫入的對象必須實現一個介面:Serializable,否則就會拋出:NotSerializableException

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.