溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

發(fā)布時間:2021-08-26 11:15:11 來源:億速云 閱讀:124 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析”這篇文章吧。

數(shù)據(jù)操作流

在io包中,提供了兩個與平臺無關(guān)的數(shù)據(jù)操作流:

數(shù)據(jù)輸入流(DataInputStream)

數(shù)據(jù)輸出流(DataOutputStream)

通常數(shù)據(jù)輸出流會按一定格式將數(shù)據(jù)輸出,再通過數(shù)據(jù)輸入流按照一定格式將數(shù)據(jù)讀入

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

DataOutputStream接口定義了一系列的writeXxx()的操作,可以寫入各種數(shù)據(jù)類型的數(shù)據(jù)。

范例:使用數(shù)據(jù)操作流寫入與讀出數(shù)據(jù)

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

import java.io.DataOutputStream ; 
import java.io.File ; 
import java.io.FileOutputStream ; 
public class DataOutputStreamDemo{ 
  public static void main(String args[]) throws Exception{  // 所有異常拋出 
    DataOutputStream dos = null ;      // 聲明數(shù)據(jù)輸出流對象 
    File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路徑 
    dos = new DataOutputStream(new FileOutputStream(f)) ;  // 實例化數(shù)據(jù)輸出流對象 
    String names[] = {"襯衣","手套","圍巾"} ; // 商品名稱 
    float prices[] = {98.3f,30.3f,50.5f} ;   // 商品價格 
    int nums[] = {3,2,1} ; // 商品數(shù)量 
    for(int i=0;i<names.length;i++){ // 循環(huán)輸出 
      dos.writeChars(names[i]) ; // 寫入字符串 
      dos.writeChar('\t') ;  // 寫入分隔符 
      dos.writeFloat(prices[i]) ; // 寫入價格 
      dos.writeChar('\t') ;  // 寫入分隔符 
      dos.writeInt(nums[i]) ; // 寫入數(shù)量 
      dos.writeChar('\n') ;  // 換行 
    } 
    dos.close() ;  // 關(guān)閉輸出流 
  } 
};
import java.io.DataInputStream ; 
import java.io.File ; 
import java.io.FileInputStream ; 
public class DataInputStreamDemo{ 
  public static void main(String args[]) throws Exception{  // 所有異常拋出 
    DataInputStream dis = null ;    // 聲明數(shù)據(jù)輸入流對象 
    File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路徑 
    dis = new DataInputStream(new FileInputStream(f)) ; // 實例化數(shù)據(jù)輸入流對象 
    String name = null ;  // 接收名稱 
    float price = 0.0f ;  // 接收價格 
    int num = 0 ;  // 接收數(shù)量 
    char temp[] = null ;  // 接收商品名稱 
    int len = 0 ;  // 保存讀取數(shù)據(jù)的個數(shù) 
    char c = 0 ;  // '\u0000' 
    try{ 
      while(true){ 
        temp = new char[200] ; // 開辟空間 
        len = 0 ; 
        while((c=dis.readChar())!='\t'){  // 接收內(nèi)容 
          temp[len] = c ; 
          len ++ ;  // 讀取長度加1 
        } 
        name = new String(temp,0,len) ; // 將字符數(shù)組變?yōu)镾tring 
        price = dis.readFloat() ;  // 讀取價格 
        dis.readChar() ;  // 讀取\t 
        num = dis.readInt() ;  // 讀取int 
        dis.readChar() ;  // 讀取\n 
        System.out.printf("名稱:%s;價格:%5.2f;數(shù)量:%d\n",name,price,num) ; 
      } 
    }catch(Exception e){} 
    dis.close() ; 
  } 
};

對象序列化

對象序列化就是把對象變?yōu)槎M制數(shù)據(jù)流的一種方法,通過對象的序列化可以方便的實現(xiàn)對象的傳輸或儲存。

如果一個類想支持初始化,則該類必須實現(xiàn)java.io.Serilizable接口。該接口定義如下:

publicinterfaceSerilizable{}

該接口中不存在方法,因此該類屬于一個標示接口,表示實現(xiàn)該的接口的類具備某種能力。

1.對象的序列化與反序列化

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

2.serialVersionUID

在序列化的操作中引入了一個serialVersionUID常量,可以通過此常量來驗證版本的一致性,在進行反序列化的時候,JVM會把傳進來的字節(jié)流中的serialVersionUID與本地對應(yīng)類的serialVersionUID進行比較,如果相同就認為是一致的,可以進行反序列化,否則就會出現(xiàn)序列化版本不一致的異常。

import java.io.Serializable ; 
public class Person implementsSerializable{ 
     private String name ;    // 聲明name屬性,但是此屬性不被序列化 
     private int age ;         // 聲明age屬性 
     publicPerson(String name,int age){     // 通過構(gòu)造設(shè)置內(nèi)容 
          this.name= name ; 
          this.age= age ; 
     } 
     publicString toString(){  // 覆寫toString()方法 
          return"姓名:" + this.name + ";年齡:" + this.age; 
     } 
};

3. 對象輸出流:ObjectOutputStream

一個對象要想進行輸出,就必須使用ObjectOutputStream類,該類定義如下

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

如果一個對象中的某個屬性不希望被序列化的話,則可以使用transient關(guān)鍵字進行聲明。

importjava.io.File ; 
importjava.io.FileOutputStream ; 
importjava.io.OutputStream ; 
importjava.io.ObjectOutputStream ; 
publicclass SerDemo01{ 
public static void main(String args[]) throwsException { 
      File f = new File("D:" +File.separator + "test.txt") ;    //定義保存路徑 
      ObjectOutputStream oos = null ;   // 聲明對象輸出流 
      OutputStream out = newFileOutputStream(f) ;   // 文件輸出流 
      oos = new ObjectOutputStream(out) ; 
      oos.writeObject(new Person("張三",30));   // 保存對象 
      oos.close() ;   // 關(guān)閉 
} 
};

4. 對象輸入流:ObjectInputStream

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

importjava.io.File ; 
importjava.io.FileInputStream ; 
importjava.io.InputStream ; 
importjava.io.ObjectInputStream ; 
publicclass SerDemo02{ 
public static void main(String args[]) throwsException { 
      File f = new File("D:" +File.separator + "test.txt") ;    //定義保存路徑 
      ObjectInputStream ois = null ;     // 聲明對象輸入流 
      InputStream input = newFileInputStream(f) ;     // 文件輸入流 
      ois = new ObjectInputStream(input) ;   // 實例化對象輸入流 
      Object obj = ois.readObject() ;     // 讀取對象 
      ois.close() ;    // 關(guān)閉 
      System.out.println(obj) ; 
} 
};

6.序列化一組對象

對象輸出時只提供了一個對象的輸出操作(writeObject(Objectobj)),并沒有提供多個對象的輸出,如果現(xiàn)在要對多個對象進行序列化的操作,則可以使用對象數(shù)組完成,由于數(shù)組是引用數(shù)據(jù)類型,所以可以直接使用Object類型進行接收。

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

importjava.io.File ; 
importjava.io.IOException ; 
importjava.io.FileOutputStream ; 
importjava.io.OutputStream ; 
importjava.io.ObjectOutputStream ; 
importjava.io.FileInputStream ; 
importjava.io.InputStream ; 
importjava.io.ObjectInputStream ; 
publicclass SerDemo05{ 
public static void main(String args[]) throwsException{ 
      Person per[] = {new Person("張三",30),newPerson("李四",31), 
          new Person("王五",32)}; 
      ser(per) ; 
      Object o[] = (Object[])dser() ; 
      for(int i=0;i<o.length;i++){ 
          Person p = (Person)o[i] ; 
          System.out.println(p) ; 
      } 
} 
public static void ser(Object obj[]) throwsException { 
      File f = new File("D:" +File.separator + "test.txt") ;    //定義保存路徑 
      ObjectOutputStream oos = null ;   // 聲明對象輸出流 
      OutputStream out = new FileOutputStream(f);   // 文件輸出流 
      oos = new ObjectOutputStream(out) ; 
      oos.writeObject(obj) ;   // 保存對象 
      oos.close() ;   // 關(guān)閉 
} 
public static Object[] dser() throws Exception{ 
      File f = new File("D:" +File.separator + "test.txt") ;    //定義保存路徑 
      ObjectInputStream ois = null ;     // 聲明對象輸入流 
      InputStream input = newFileInputStream(f) ;     // 文件輸入流 
      ois = new ObjectInputStream(input) ;   // 實例化對象輸入流 
      Object obj[] =(Object[])ois.readObject() ;    // 讀取對象 
      ois.close() ;    // 關(guān)閉 
      return obj ; 
} 
};

數(shù)組能儲存的對象數(shù)量有限,因此可以使用類集進行序列化的操作。

壓縮流

在Java中為了減少傳輸時的數(shù)據(jù)量也專門提供了壓縮流,可以將文件或者文件夾壓縮成ZIP、JAR、GZIP等格式。

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

該流使用較少,因此只做簡要介紹。

java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析

以上是“java中IO數(shù)據(jù)操作流、對象序列化、壓縮流的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)
推薦閱讀:
  1. java中的IO流
  2. IO流分析

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI