關于Java的對象序列化流和反序列化流詳細解讀
對象序列化
- 對象序列化:就是將對象保存到磁盤中,或者在網(wǎng)絡中傳輸對象。
- 這種機制就是使用一個字節(jié)序列表示一個對象,該字節(jié)序列包含:對象的類型、對象的數(shù)據(jù)和對象中存儲的屬性等信息,字節(jié)序列寫到文件之后,相當于文件中持久保存了一個對象的信息
- 反之,自己序列還可以從文件中讀取回來,重構對象,對它進行反序列化。
要實現(xiàn)序列化和反序列化就要使用對象序列化流和對象反序列化流:
- 對象序列化流:ObjectOutputStream
- 對象反序列化流:ObjectInputStream
一、對象序列化流
對象序列化流:ObjectOutputStream
- 將Java對象的原始數(shù)據(jù)類型和圖形寫入OutputStream,可以使用ObjectInputStream讀取(重構)對象??梢酝ㄟ^使用流的文件來實現(xiàn)對象的持久存儲。如果流是網(wǎng)絡套接字流,則可以在另一個主機上或另一個進程中重構對象。
構造方法:
- ObjectOutputStream(OutputStream out):創(chuàng)建一個寫入指定的OutputStream的ObjectOutputStream
序列化對象的方法:
- void writeObject(Object obj):將指定的對象寫入ObjectOutputStream
類的序列化由實現(xiàn)java.io.Serializable接口的類啟用,不實現(xiàn)此接口的類不會使任何狀態(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ù)庫名稱
*/
private String databaseName;
/**
* 數(shù)據(jù)庫的描述
*/
private Integer databaseId;
}對象序列化流代碼
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);將指定的對象寫入ObjectOutputStream
oos.writeObject(dataset);
//釋放資源
oos.close();
}
}二、對象反序列化流
對象反序列化流:ObjectInputStream
- ObjectInputStream反序列化先前使用ObjectOutputStream編寫的原始數(shù)據(jù)和對象
構造方法:
- ObjectInputStream(InputStream in):創(chuàng)建從指定的InputStream讀取的ObjectInputStream
反序列化對象的方法:
- Object readObject():從ObjectInputStream讀取一個對象
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讀取一個對象
Object obj = ois.readObject();
Dataset dataset = (Dataset) obj;
System.out.println(dataset.getDatabaseName() + ":" + dataset.getDatabaseId());
ois.close();
}
}三、serialVersionUID和transient
用對象序列化流序列化了一個對象后,假如修改了對象所屬的類文件,讀取數(shù)據(jù)會不會出問題呢?
- 會出問題,拋出InvalidClassException異常
出問題,如何解決呢?
- 給對象所屬的類加一個值:private static final long serialVersionUID = 42L;
一個對象中的某個成員變量的值不想被序列化,又該如何實現(xiàn)呢?
- 給成員變量加transient關鍵字修飾,該關鍵字標記的成員變量不參與序列化過程
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ù)庫名稱
*/
private String databaseName;
/**
* 數(shù)據(jù)庫的描述
*/
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讀取一個對象
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);將指定的對象寫入ObjectOutputStream
oos.writeObject(dataset);
//釋放資源
oos.close();
}
}到此這篇關于關于Java的對象序列化流和反序列化流詳細解讀的文章就介紹到這了,更多相關Java對象序列化流和反序列化流內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
@Transactional注解:多個事務嵌套時,獨立事務處理方式
這篇文章主要介紹了@Transactional注解:多個事務嵌套時,獨立事務處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01
解決IDEA Maven下載依賴時報錯ERROR - #org.jetbrains.ide
這篇文章主要介紹了解決IDEA Maven下載依賴時報錯ERROR - #org.jetbrains.idea.maven - Cannot reconnect.問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Spring AOP 對象內(nèi)部方法間的嵌套調(diào)用方式
這篇文章主要介紹了Spring AOP 對象內(nèi)部方法間的嵌套調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08

