您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“java中IO數據操作流、對象序列化、壓縮流的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“java中IO數據操作流、對象序列化、壓縮流的示例分析”這篇文章吧。
數據操作流
在io包中,提供了兩個與平臺無關的數據操作流:
數據輸入流(DataInputStream)
數據輸出流(DataOutputStream)
通常數據輸出流會按一定格式將數據輸出,再通過數據輸入流按照一定格式將數據讀入
DataOutputStream接口定義了一系列的writeXxx()的操作,可以寫入各種數據類型的數據。
范例:使用數據操作流寫入與讀出數據
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 ; // 聲明數據輸出流對象 File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路徑 dos = new DataOutputStream(new FileOutputStream(f)) ; // 實例化數據輸出流對象 String names[] = {"襯衣","手套","圍巾"} ; // 商品名稱 float prices[] = {98.3f,30.3f,50.5f} ; // 商品價格 int nums[] = {3,2,1} ; // 商品數量 for(int i=0;i<names.length;i++){ // 循環輸出 dos.writeChars(names[i]) ; // 寫入字符串 dos.writeChar('\t') ; // 寫入分隔符 dos.writeFloat(prices[i]) ; // 寫入價格 dos.writeChar('\t') ; // 寫入分隔符 dos.writeInt(nums[i]) ; // 寫入數量 dos.writeChar('\n') ; // 換行 } dos.close() ; // 關閉輸出流 } };
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 ; // 聲明數據輸入流對象 File f = new File("d:" + File.separator + "order.txt") ; // 文件的保存路徑 dis = new DataInputStream(new FileInputStream(f)) ; // 實例化數據輸入流對象 String name = null ; // 接收名稱 float price = 0.0f ; // 接收價格 int num = 0 ; // 接收數量 char temp[] = null ; // 接收商品名稱 int len = 0 ; // 保存讀取數據的個數 char c = 0 ; // '\u0000' try{ while(true){ temp = new char[200] ; // 開辟空間 len = 0 ; while((c=dis.readChar())!='\t'){ // 接收內容 temp[len] = c ; len ++ ; // 讀取長度加1 } name = new String(temp,0,len) ; // 將字符數組變為String price = dis.readFloat() ; // 讀取價格 dis.readChar() ; // 讀取\t num = dis.readInt() ; // 讀取int dis.readChar() ; // 讀取\n System.out.printf("名稱:%s;價格:%5.2f;數量:%d\n",name,price,num) ; } }catch(Exception e){} dis.close() ; } };
對象序列化
對象序列化就是把對象變為二進制數據流的一種方法,通過對象的序列化可以方便的實現對象的傳輸或儲存。
如果一個類想支持初始化,則該類必須實現java.io.Serilizable接口。該接口定義如下:
publicinterfaceSerilizable{}
該接口中不存在方法,因此該類屬于一個標示接口,表示實現該的接口的類具備某種能力。
1.對象的序列化與反序列化
2.serialVersionUID
在序列化的操作中引入了一個serialVersionUID常量,可以通過此常量來驗證版本的一致性,在進行反序列化的時候,JVM會把傳進來的字節流中的serialVersionUID與本地對應類的serialVersionUID進行比較,如果相同就認為是一致的,可以進行反序列化,否則就會出現序列化版本不一致的異常。
import java.io.Serializable ; public class Person implementsSerializable{ private String name ; // 聲明name屬性,但是此屬性不被序列化 private int age ; // 聲明age屬性 publicPerson(String name,int age){ // 通過構造設置內容 this.name= name ; this.age= age ; } publicString toString(){ // 覆寫toString()方法 return"姓名:" + this.name + ";年齡:" + this.age; } };
3. 對象輸出流:ObjectOutputStream
一個對象要想進行輸出,就必須使用ObjectOutputStream類,該類定義如下
如果一個對象中的某個屬性不希望被序列化的話,則可以使用transient關鍵字進行聲明。
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() ; // 關閉 } };
4. 對象輸入流:ObjectInputStream
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() ; // 關閉 System.out.println(obj) ; } };
6.序列化一組對象
對象輸出時只提供了一個對象的輸出操作(writeObject(Objectobj)),并沒有提供多個對象的輸出,如果現在要對多個對象進行序列化的操作,則可以使用對象數組完成,由于數組是引用數據類型,所以可以直接使用Object類型進行接收。
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() ; // 關閉 } 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() ; // 關閉 return obj ; } };
數組能儲存的對象數量有限,因此可以使用類集進行序列化的操作。
壓縮流
在Java中為了減少傳輸時的數據量也專門提供了壓縮流,可以將文件或者文件夾壓縮成ZIP、JAR、GZIP等格式。
該流使用較少,因此只做簡要介紹。
以上是“java中IO數據操作流、對象序列化、壓縮流的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。