国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

一文帶你徹底理解Java序列化和反序列化

瀏覽:5日期:2022-08-25 15:52:36

Java序列化是什么?

Java序列化是指把Java對象轉換為字節序列的過程,Java反序列化是指把字節序列恢復為Java對象的過程。

反序列化: 客戶端重文件,或者網絡中獲取到文件以后,在內存中重構對象。

序列化: 對象序列化的最重要的作用是傳遞和保存對象的時候,保證對象的完整性和可傳遞性。方便字節可以在網絡上傳輸以及保存在本地文件。

為什么需要序列化和反序列化

實現分布式

核心在于RMI,可以利用對象序列化運行遠程主機上的服務,實現運行的時候,就像在本地上運行Java對象一樣。

實現遞歸保存對象

進行序列化的時候,單單并不是保存一個對象,而是遞歸的保存一整個對象序列,即遞歸保存,通過反序列化,可以遞歸的得到一整個對象序列。

序列信息可以永久保存

用于序列化的信息,可以永久保存為文件,或者保存在數據庫中,在使用的時候,再次隨時恢復到內存中,實現內存中的類的信息可以永久的保存。

數據格式統一

比照Linux的一切皆文件的思想,同時Java也是這樣的思想,讓數據格式盡可能的統一,讓對象,文件,數據,等等許許多多不同的格式,都讓其統一,以及保存。實現數據可以完整的傳輸和保存。然后進行反序列化還原,即,對象還是對象,文件還是文件。

實現Java序列化和反序列化

要進行反序列化需要實現一個接口。即 Serializabei接口。

代碼如下

需要轉化的類

package common.lang;import java.io.Serializable;import org.apache.commons.lang3.builder.ToStringBuilder;import org.apache.commons.lang3.builder.ToStringStyle;public class User1 implements Serializable{ private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) .append('name', name) .append('age', age) .toString(); }}

進行序列化,以及反序列化

package common.lang;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;public class SerializableDemo1 { public static void main(String[] args) throws Exception, IOException { //初始化對象 User1 user = new User1(); user.setName('yaomy'); user.setAge(23); System.out.println(user); //序列化對象到文件中 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream('template')); oos.writeObject(user); oos.close(); //反序列化 File file = new File('template'); ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file)); User1 newUser = (User1)ois.readObject(); System.out.println(newUser.toString()); }}

另一個序列化接口 Externalizable

繼續實現Externalizable接口

package common.lang;import java.io.Externalizable;import java.io.IOException;import java.io.ObjectInput;import java.io.ObjectOutput;import org.apache.commons.lang3.builder.ToStringBuilder;import org.apache.commons.lang3.builder.ToStringStyle;public class User1 implements Externalizable{ private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) .append('name', name) .append('age', age) .toString(); } @Override public void writeExternal(ObjectOutput out) throws IOException { // TODO Auto-generated method stub } @Override public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { // TODO Auto-generated method stub }}

進行序列化以及反序列化

package common.lang;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;public class SerializableDemo1 { public static void main(String[] args) throws Exception, IOException { //初始化對象 User1 user = new User1(); user.setName('yaomy'); user.setAge(23); System.out.println(user); //序列化對象到文件中 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream('template')); oos.writeObject(user); oos.close(); //反序列化 File file = new File('template'); ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file)); User1 newUser = (User1)ois.readObject(); System.out.println(newUser.toString()); ois.close(); }}

查看輸出的結構

common.lang.User1@6ef64f64[name=yaomyage=23]common.lang.User1@184c9860[name=<null>age=0]

根據輸出的結果可以看到,對User1進行序列化然后再反序列化之后對象的屬性都恢復成了默認值,即,之前那個對象的狀態沒有被持久保存下來,這就是Externalization和Serialization接口的區別,其中前者接口會被恢復成為默認值,后者接口不會恢復默認值。

如果需要恢復,這里就需要重寫兩個抽象方法,分別是writeExternal與readExternal兩個抽象方法。

package common.lang;import java.io.Externalizable;import java.io.IOException;import java.io.ObjectInput;import java.io.ObjectOutput;import org.apache.commons.lang3.builder.ToStringBuilder;import org.apache.commons.lang3.builder.ToStringStyle;public class User1 implements Externalizable{ private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE) .append('name', name) .append('age', age) .toString(); } @Override public void writeExternal(ObjectOutput out) throws IOException { out.writeObject(name); out.writeInt(age); } @Override public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { name = (String)in.readObject(); age = in.readInt(); }}

package common.lang;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;public class SerializableDemo1 { public static void main(String[] args) throws Exception, IOException { //初始化對象 User1 user = new User1(); user.setName('yaomy'); user.setAge(23); System.out.println(user); //序列化對象到文件中 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream('template')); oos.writeObject(user); oos.close(); //反序列化 File file = new File('template'); ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file)); User1 newUser = (User1)ois.readObject(); System.out.println(newUser.toString()); ois.close(); }}

輸出的結果

common.lang.User1@6cd66725[name=yaomyage=23]common.lang.User1@19160e64[name=yaomyage=23]

靜態變量的序列化

實例

public class Test implements Serializable { private static final long serialVersionUID = 1L; public static int staticVar = 5; public static void main(String[] args) { try { //初始時staticVar為5 ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream('result.obj')); out.writeObject(new Test()); out.close(); //序列化后修改為10 Test.staticVar = 10; ObjectInputStream oin = new ObjectInputStream(new FileInputStream( 'result.obj')); Test t = (Test) oin.readObject(); oin.close(); //再讀取,通過t.staticVar打印新的值 System.out.println(t.staticVar); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } }}

代碼闡述一下過程,在main方法中,對象序列化以后,修改靜態變量的數值,再把序列化后的對象讀取出來,此時輸出的值為10.

理解如下: 打印的staticVar是從讀取對象里獲得的,打印10的原因是因為序列化時,不保存靜態變量,只保存內存中的狀態。此時修改靜態變量的值,修改的是類中的值,輸出的也是類中的值,和內存無關。

Transient關鍵字

Transient關鍵字,加上以后,可以阻止該變量被序列化到文件中,反序列化以后,變量的值設定為初始值。

以上就是一文帶你徹底理解Java序列化和反序列化的詳細內容,更多關于Java序列化和反序列化的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 日韩一级a毛片欧美一级 | 不卡午夜视频 | 国产精品亚洲午夜不卡 | 国产亚洲图片 | 性色a| 免费观看欧美成人禁片 | 性8sex亚洲区入口 | 亚洲天堂免费观看 | 午夜在线影院 | 亚洲免费视频一区 | 美女张开腿男人桶 | 一级黄色α片 | 免费精品99久久国产综合精品 | 怡红院成人网 | 亚洲视频精选 | 日本高清福利视频在线观看 | 亚洲网址在线观看 | 91久久99 | 欧日韩视频777888 | 韩国一大片a毛片 | 亚洲欧美日韩色 | 国产成人午夜精品免费视频 | 亚洲国产成人精品一区二区三区 | 男女一级爽爽快视频 | 国产在线视频h | 人操人碰| 成人免费在线观看视频 | 国产女王女m视频vk 国产女王丨vk | 亚洲一区二区在线 | 亚洲图片国产日韩欧美 | 97国产成人精品免费视频 | 中文字幕在线乱码不卡区区 | 日韩免费观看一级毛片看看 | 国产v精品成人免费视频400条 | 色综合久久久高清综合久久久 | 精品国产欧美一区二区 | 国产日韩一区二区三区在线播放 | 亚洲精品免费在线 | 亚洲精品国产综合99久久一区 | 免费在线观看a级片 | 欧美一级情欲片在线 |