亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于Java的對(duì)象序列化流和反序列化流詳細(xì)解讀

 更新時(shí)間:2023年05月19日 11:28:00   作者:最笨的羊羊  
這篇文章主要介紹了關(guān)于Java的對(duì)象序列化流和反序列化流,對(duì)象序列化:就是將對(duì)象保存到磁盤中,或者在網(wǎng)絡(luò)中傳輸對(duì)象,反之,自己序列還可以從文件中讀取回來(lái),重構(gòu)對(duì)象,對(duì)它進(jìn)行反序列化,需要的朋友可以參考下

 對(duì)象序列化

  • 對(duì)象序列化:就是將對(duì)象保存到磁盤中,或者在網(wǎng)絡(luò)中傳輸對(duì)象。
  • 這種機(jī)制就是使用一個(gè)字節(jié)序列表示一個(gè)對(duì)象,該字節(jié)序列包含:對(duì)象的類型、對(duì)象的數(shù)據(jù)和對(duì)象中存儲(chǔ)的屬性等信息,字節(jié)序列寫到文件之后,相當(dāng)于文件中持久保存了一個(gè)對(duì)象的信息
  • 反之,自己序列還可以從文件中讀取回來(lái),重構(gòu)對(duì)象,對(duì)它進(jìn)行反序列化。

要實(shí)現(xiàn)序列化和反序列化就要使用對(duì)象序列化流和對(duì)象反序列化流:

  • 對(duì)象序列化流:ObjectOutputStream
  • 對(duì)象反序列化流:ObjectInputStream

一、對(duì)象序列化流

對(duì)象序列化流:ObjectOutputStream

  • 將Java對(duì)象的原始數(shù)據(jù)類型和圖形寫入OutputStream,可以使用ObjectInputStream讀取(重構(gòu))對(duì)象??梢酝ㄟ^(guò)使用流的文件來(lái)實(shí)現(xiàn)對(duì)象的持久存儲(chǔ)。如果流是網(wǎng)絡(luò)套接字流,則可以在另一個(gè)主機(jī)上或另一個(gè)進(jìn)程中重構(gòu)對(duì)象。

構(gòu)造方法:

  • ObjectOutputStream(OutputStream out):創(chuàng)建一個(gè)寫入指定的OutputStream的ObjectOutputStream

序列化對(duì)象的方法:

  • void writeObject(Object obj):將指定的對(duì)象寫入ObjectOutputStream

類的序列化由實(shí)現(xiàn)java.io.Serializable接口的類啟用,不實(shí)現(xiàn)此接口的類不會(huì)使任何狀態(tài)序列化或反序列化。

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class Dataset implements Serializable {
     /* 數(shù)據(jù)庫(kù)名稱
     */
    private String databaseName;
    /**
     * 數(shù)據(jù)庫(kù)的描述
     */
    private Integer databaseId;
}

對(duì)象序列化流代碼

import com.bigdata.plus.Dataset;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
public class ObjectOutputStreamDemo {
    public static void main(String[] args) throws IOException {
        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("/Users/f/project/learn/src/main/java" +
                "/com/bigdata/plus/collection/test.txt"));
        Dataset dataset = new Dataset("dw", 1);
        //void writeObject(Object obj);將指定的對(duì)象寫入ObjectOutputStream
        oos.writeObject(dataset);
        //釋放資源
        oos.close();
    }
}

二、對(duì)象反序列化流

對(duì)象反序列化流:ObjectInputStream

  • ObjectInputStream反序列化先前使用ObjectOutputStream編寫的原始數(shù)據(jù)和對(duì)象

構(gòu)造方法:

  • ObjectInputStream(InputStream in):創(chuàng)建從指定的InputStream讀取的ObjectInputStream

反序列化對(duì)象的方法:

  • Object readObject():從ObjectInputStream讀取一個(gè)對(duì)象
import com.bigdata.plus.Dataset;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
public class ObjectInputStreamDemo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        //創(chuàng)建FileInputStream
        FileInputStream fileInputStream = new FileInputStream("/Users/f/project/learn/src/main/java/com/bigdata/plus/collection" +
                "/test.txt");
        //創(chuàng)建從指定宕InputStream讀取的ObjectInputStream
        ObjectInputStream ois = new ObjectInputStream(fileInputStream);
        //Object readObject():從ObjectInputStream讀取一個(gè)對(duì)象
        Object obj = ois.readObject();
        Dataset dataset = (Dataset) obj;
        System.out.println(dataset.getDatabaseName() + ":" + dataset.getDatabaseId());
        ois.close();
    }
}

三、serialVersionUID和transient

用對(duì)象序列化流序列化了一個(gè)對(duì)象后,假如修改了對(duì)象所屬的類文件,讀取數(shù)據(jù)會(huì)不會(huì)出問(wèn)題呢?

  • 會(huì)出問(wèn)題,拋出InvalidClassException異常

出問(wèn)題,如何解決呢?

  • 給對(duì)象所屬的類加一個(gè)值:private static final long serialVersionUID = 42L;

一個(gè)對(duì)象中的某個(gè)成員變量的值不想被序列化,又該如何實(shí)現(xiàn)呢?

  • 給成員變量加transient關(guān)鍵字修飾,該關(guān)鍵字標(biāo)記的成員變量不參與序列化過(guò)程

transient使成員變量不參與序列化

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class Dataset implements Serializable {
    private static final long serialVersionUID = 42L;
     /* 數(shù)據(jù)庫(kù)名稱
     */
    private String databaseName;
    /**
     * 數(shù)據(jù)庫(kù)的描述
     */
    private transient Integer databaseId;
}

序列化和反序列化

import com.bigdata.plus.Dataset;
import java.io.*;
public class ObjectStreamDemo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        read();
        write();
    }
    //反序列化
    public static void read() throws IOException, ClassNotFoundException {
        //創(chuàng)建FileInputStream
        FileInputStream fileInputStream = new FileInputStream("/Users/f/project/learn/src/main/java/com/bigdata/plus/collection" +
                "/test.txt");
        //創(chuàng)建從指定宕InputStream讀取的ObjectInputStream
        ObjectInputStream ois = new ObjectInputStream(fileInputStream);
        //Object readObject():從ObjectInputStream讀取一個(gè)對(duì)象
        Object obj = ois.readObject();
        Dataset dataset = (Dataset) obj;
        System.out.println(dataset.getDatabaseName() + ":" + dataset.getDatabaseId());
        ois.close();
    }
    public static void write() throws IOException {
        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("/Users/f/project/learn/src/main/java" +
                "/com/bigdata/plus/collection/test.txt"));
        Dataset dataset = new Dataset("dw", 1);
        //void writeObject(Object obj);將指定的對(duì)象寫入ObjectOutputStream
        oos.writeObject(dataset);
        //釋放資源
        oos.close();
    }
}

到此這篇關(guān)于關(guān)于Java的對(duì)象序列化流和反序列化流詳細(xì)解讀的文章就介紹到這了,更多相關(guān)Java對(duì)象序列化流和反序列化流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論