溫馨提示×

溫馨提示×

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

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

java的序列化怎么實(shí)現(xiàn)

發(fā)布時間:2020-06-28 09:52:26 來源:億速云 閱讀:165 作者:Leah 欄目:編程語言

本篇文章為大家展示了java的序列化怎么實(shí)現(xiàn),代碼簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

簡要解釋:

序列化就是一種用來處理對象流的機(jī)制,所謂對象流也就是將對象的內(nèi)容進(jìn)行流化。可以對流化后的對象進(jìn)行讀寫操作,也可將流化后的對象傳輸于網(wǎng)絡(luò)之間。

序列化是為了解決在對對象流進(jìn)行讀寫操作時所引發(fā)的問題。序列化的實(shí)現(xiàn):將需要被序列化的類實(shí)現(xiàn)Serializable接口,該接口沒有需要實(shí)現(xiàn)的方法,implements Serializable只是為了標(biāo)注該對象是可被序列化的,然后使用一個輸出流(如:FileOutputStream)來構(gòu)造一個ObjectOutputStream(對象流)對象,接著,使用ObjectOutputStream對象的writeObject(Object obj)方法就可以將參數(shù)為obj的對象寫出(即保存其狀態(tài)),要恢復(fù)的話則用輸入流。

詳細(xì)解釋:

當(dāng)兩個進(jìn)程在進(jìn)行遠(yuǎn)程通信時,彼此可以發(fā)送各種類型的數(shù)據(jù)。無論是何種類型的數(shù)據(jù),都會以二進(jìn)制序列的形式在網(wǎng)絡(luò)上傳送。發(fā)送方需要把這個Java對象轉(zhuǎn)換為字節(jié)序列,才能在網(wǎng)絡(luò)上傳送;接收方則需要把字節(jié)序列再恢復(fù)為Java對象。

只能將支持 java.io.Serializable 接口的對象寫入流中。每個 serializable 對象的類都被編碼,編碼內(nèi)容包括類名和類簽名、對象的字段值和數(shù)組值,以及從初始對象中引用的其他所有對象的閉包。

1.概念

序列化:把Java對象轉(zhuǎn)換為字節(jié)序列的過程。

反序列化:把字節(jié)序列恢復(fù)為Java對象的過程。

2.用途

對象的序列化主要有兩種用途:

(1)把對象的字節(jié)序列永久地保存到硬盤上,通常存放在一個文件中;

(2)在網(wǎng)絡(luò)上傳送對象的字節(jié)序列。

3.對象序列化

序列化API

java.io.ObjectOutputStream代表對象輸出流,它的writeObject(Object obj)方法可對參數(shù)指定的obj對象進(jìn)行序列化,把得到的字節(jié)序列寫到一個目標(biāo)輸出流中。只有實(shí)現(xiàn)了Serializable和Externalizable接口的類的對象才能被序列化。

java.io.ObjectInputStream代表對象輸入流,它的readObject()方法從一個源輸入流中讀取字節(jié)序列,再把它們反序列化為一個對象,并將其返回。

代碼示例

import java.io.*;
import java.util.Date;

public class ObjectSaver {
   public static void main(String[] args) throws Exception {
        /*其中的  D:\\objectFile.obj 表示存放序列化對象的文件*/

        
        //序列化對象
         ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("D:\\objectFile.obj"));
         Customer customer = new Customer("王麻子", 24);    
         out.writeObject("你好!");    //寫入字面值常量
         out.writeObject(new Date());    //寫入匿名Date對象
         out.writeObject(customer);    //寫入customer對象
         out.close(); 
         
         //反序列化對象
         ObjectInputStream in = new ObjectInputStream(new FileInputStream("D:\\objectFile.obj"));
         System.out.println("obj1 " + (String) in.readObject());    //讀取字面值常量
         System.out.println("obj2 " + (Date) in.readObject());    //讀取匿名Date對象
         Customer obj3 = (Customer) in.readObject();    //讀取customer對象
         System.out.println("obj3 " + obj3);
         in.close();
     }
 }
 
 class Customer implements Serializable {
     private String name;
     private int age;
     public Customer(String name, int age) {
         this.name = name;
         this.age = age;
     }
 
     public String toString() {
         return "name=" + name + ", age=" + age;
     }
 }

4.說明

讀取對象的順序與寫入時的順序要一致。

對象的默認(rèn)序列化機(jī)制寫入的內(nèi)容是:對象的類,類簽名,以及非瞬態(tài)和非靜態(tài)字段的值。

上述內(nèi)容就是java的序列化怎么實(shí)現(xiàn),你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

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

AI