溫馨提示×

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

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

Java對(duì)象被序列化方法有哪些

發(fā)布時(shí)間:2021-06-30 17:10:00 來源:億速云 閱讀:129 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Java對(duì)象被序列化方法有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Java對(duì)象被序列化方法有哪些”吧!

Java對(duì)象為什么需要被序列化

  • 序列化能夠?qū)?duì)象轉(zhuǎn)為二進(jìn)制流,對(duì)象就可以方便的在網(wǎng)絡(luò)中被傳輸和保存。

實(shí)現(xiàn)序列化的方式

  • 實(shí)現(xiàn)Serializable接口

  • 實(shí)現(xiàn)Externalizable接口

**這兩個(gè)接口的區(qū)別是:**Serializable接口會(huì)自動(dòng)給對(duì)象的所有屬性標(biāo)記為可被序列化。而Externalizable接口默認(rèn)不給任何屬性標(biāo)記可被序列化,如果需要序列化,需要重寫兩個(gè)方法,分別是writeExternal()和readExternal(),然后在這兩個(gè)方法中標(biāo)記需要被序列化的對(duì)象屬性。

實(shí)現(xiàn)這兩個(gè)接口,只是表示該對(duì)象可以被序列化,真正的做序列化操作,需要ObjectOutputStream對(duì)象操作。接下來就用編碼的方式體現(xiàn)序列化。

先寫個(gè)序列化操作的工具類,用于實(shí)現(xiàn)序列化和反序列化。

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

/**
 * 序列化操作工具類
 * @author 楊33
 * @date 2020/6/21 15:22
 */
public class SerializeUtil {
    /**
     * 將對(duì)象轉(zhuǎn)成字節(jié)數(shù)組
     * @param object 需要序列化的對(duì)象
     * @return
     * @throws IOException
     */
    public static byte[] serialize(Object object) throws IOException{
        if(object == null){
            return null;
        }
        ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
        ObjectOutputStream objectOutputStream = new ObjectOutputStream(byteArrayOutputStream);
        objectOutputStream.writeObject(object);
        return byteArrayOutputStream.toByteArray();
    }

    /**
     * 反序列化
     * @param bytes 對(duì)象字節(jié)數(shù)組
     * @throws IOException
     * @throws ClassNotFoundException
     */
    public static Object unserialize(byte[] bytes) throws IOException, ClassNotFoundException{
        ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(bytes);
        ObjectInputStream objectInputStream = new ObjectInputStream(byteArrayInputStream);
        return objectInputStream.readObject();
    }
}

先來實(shí)現(xiàn)一個(gè)Serializable接口

/**
 * @author 楊33
 * @date 2020/6/21 14:20
 */
public class Owner implements Serializable {
    private String name;

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}

測(cè)試下:

import java.io.IOException;
/**
 * @author 楊33
 * @date 2020/6/21 14:54
 */
public class Demo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        Owner owner = new Owner();
        owner.setName("李四");
        //序列化
        byte[] serialize = SerializeUtil.serialize(owner);
        System.out.println("序列化的效果:" + serialize);
        //反序列化
        owner = (Owner)SerializeUtil.unserialize(serialize);
        System.out.println("反序列化的效果:" + owner.getName());
    }
}

控制臺(tái)打印結(jié)果:

序列化的效果:[B@58ca40be
反序列化的效果:李四

如果這個(gè)name字段不需要被序列化,可以使用關(guān)鍵字transient修飾,比如:

private transient String name;

此時(shí)測(cè)試一下,name字段就不會(huì)被序列化,反序列化后拿到的值就為null。

序列化的效果:[B@4ca49360
反序列化的效果:null

再實(shí)現(xiàn)一個(gè)Externalizable接口

/**
 * @author 楊33
 * @date 2020/6/21 14:20
 */
public class Medium implements Externalizable {
    private String name;
    private String sex;

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }

    public void writeExternal(ObjectOutput out) throws IOException {
        out.writeObject(name);
        out.writeObject(sex);
    }

    public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
        name = (String) in.readObject();
        sex = (String) in.readObject();
    }
}

測(cè)試下:

import java.io.IOException;
/**
 * @author 楊33
 * @date 2020/6/21 14:54
 */
public class Demo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        Medium medium = new Medium();
        medium.setName("李四");
        medium.setSex("女");
        //序列化
        byte[] serialize = SerializeUtil.serialize(medium);
        System.out.println("序列化的效果:" + serialize);
        //反序列化
        medium = (Medium)SerializeUtil.unserialize(serialize);
        System.out.println("反序列化的效果:" + medium.getName());
        System.out.println("反序列化的效果:" + medium.getSex());
    }
}

控制臺(tái)打印結(jié)果:

序列化的效果:[B@71d9a2ab
反序列化的效果:李四
反序列化的效果:女

如果字段sex不需要被序列化,那么可以在方法writeExternal()和readExternal()中去掉設(shè)置sex字段的代碼。最后測(cè)試,sex字段不會(huì)被序列化,反序列化后拿到的值就為null。

序列化的效果:[B@746c2f2
反序列化的效果:李四
反序列化的效果:null

到此,相信大家對(duì)“Java對(duì)象被序列化方法有哪些”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

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

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

AI