關(guān)于Java的對象序列化流和反序列化流詳細(xì)解讀
對象序列化
- 對象序列化:就是將對象保存到磁盤中,或者在網(wǎng)絡(luò)中傳輸對象。
- 這種機(jī)制就是使用一個字節(jié)序列表示一個對象,該字節(jié)序列包含:對象的類型、對象的數(shù)據(jù)和對象中存儲的屬性等信息,字節(jié)序列寫到文件之后,相當(dāng)于文件中持久保存了一個對象的信息
- 反之,自己序列還可以從文件中讀取回來,重構(gòu)對象,對它進(jìn)行反序列化。
要實現(xiàn)序列化和反序列化就要使用對象序列化流和對象反序列化流:
- 對象序列化流:ObjectOutputStream
- 對象反序列化流:ObjectInputStream
一、對象序列化流
對象序列化流:ObjectOutputStream
- 將Java對象的原始數(shù)據(jù)類型和圖形寫入OutputStream,可以使用ObjectInputStream讀取(重構(gòu))對象??梢酝ㄟ^使用流的文件來實現(xiàn)對象的持久存儲。如果流是網(wǎng)絡(luò)套接字流,則可以在另一個主機(jī)上或另一個進(jìn)程中重構(gòu)對象。
構(gòu)造方法:
- 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ù)和對象
構(gòu)造方法:
- 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關(guān)鍵字修飾,該關(guān)鍵字標(biāo)記的成員變量不參與序列化過程
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(); } }
到此這篇關(guān)于關(guān)于Java的對象序列化流和反序列化流詳細(xì)解讀的文章就介紹到這了,更多相關(guān)Java對象序列化流和反序列化流內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
@Transactional注解:多個事務(wù)嵌套時,獨(dú)立事務(wù)處理方式
這篇文章主要介紹了@Transactional注解:多個事務(wù)嵌套時,獨(dú)立事務(wù)處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01解決IDEA Maven下載依賴時報錯ERROR - #org.jetbrains.ide
這篇文章主要介紹了解決IDEA Maven下載依賴時報錯ERROR - #org.jetbrains.idea.maven - Cannot reconnect.問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Spring AOP 對象內(nèi)部方法間的嵌套調(diào)用方式
這篇文章主要介紹了Spring AOP 對象內(nèi)部方法間的嵌套調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08java簡單實現(xiàn)用語音讀txt文檔方法總結(jié)
在本篇文章里小編給大家整理了關(guān)于java簡單實現(xiàn)用語音讀txt文檔的詳細(xì)方法總結(jié),有需要的朋友們參考下。2019-06-06Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(26)
下面小編就為大家?guī)硪黄狫ava基礎(chǔ)的幾道練習(xí)題(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望可以幫到你2021-07-07