日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:26日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
麻豆国产91在线播放| 亚洲国产日韩欧美在线| 97在线精品| 国产成人精品福利| 日韩大片在线播放| 播放一区二区| 国内精品99| 丝袜国产日韩另类美女| 亚洲影院天堂中文av色| 午夜精品一区二区三区国产| 国产 日韩 欧美一区| 天堂网av成人| 黄色亚洲大片免费在线观看| 午夜影院欧美| 免费成人在线影院| 国产日韩亚洲| 蜜桃av.网站在线观看| 黄色精品网站| 国产欧美三级| 日韩毛片视频| 日本中文字幕视频一区| 国产精品中文字幕亚洲欧美 | 精品美女在线视频| 亚洲欧洲高清| 国产精品日韩久久久| 国产精品老牛| 日本天堂一区| 日本午夜大片a在线观看| 香蕉久久99| 国产精品麻豆成人av电影艾秋 | 美女尤物国产一区| jiujiure精品视频播放| 日韩精品福利一区二区三区| 麻豆精品久久久| 丝袜美腿亚洲色图| 国产a亚洲精品| 国产午夜精品一区二区三区欧美 | 精品一区二区三区中文字幕在线| 久久青草久久| 国产精品久一| 亚洲精一区二区三区| 国产精品高颜值在线观看| 亚洲欧洲av| 亚洲福利免费| 国产精品99一区二区三| 日韩精品电影一区亚洲| 精品在线91| 精品视频网站| 国产日本精品| 在线精品视频一区| 欧美日韩四区| 日韩毛片在线| 国产aⅴ精品一区二区四区| 美国三级日本三级久久99| 国产在视频一区二区三区吞精| 天堂va蜜桃一区二区三区| 日韩中文首页| 色老板在线视频一区二区| 国产一区二区久久久久| 国产精选一区| 国产欧美日韩免费观看| 一区二区精品| 亚洲午夜av| 91精品国产乱码久久久久久久| 久久99视频| 日本视频中文字幕一区二区三区| 红桃视频亚洲| 久久午夜精品一区二区| 亚洲一区二区三区高清| 免费不卡中文字幕在线| 亚洲1234区| 999久久久精品国产| 丝袜美腿诱惑一区二区三区| 国产成人精品亚洲日本在线观看| 在线手机中文字幕| 国产h片在线观看| 久久久久99| 高潮一区二区| 亚洲激情不卡| 日韩精品一区二区三区中文字幕| 免费观看在线综合色| 日韩黄色av| 久久精品毛片| 久久精品国语| 午夜一级在线看亚洲| 亚洲性视频在线| 久久字幕精品一区| 日韩精品久久久久久久电影99爱| 精品一区视频| 免费观看在线色综合| 日韩av二区在线播放| 欧美成a人片免费观看久久五月天| 伊人久久亚洲热| 日韩av不卡一区二区| 美女在线视频一区| 激情综合亚洲| 荡女精品导航| 中文国产一区| 国产精品白丝一区二区三区| 国产亚洲精品美女久久 | 国产精品一区二区三区四区在线观看| 国产麻豆一区二区三区| 精品丝袜在线| 伊人国产精品| 91一区二区三区四区| 久久亚洲欧洲| 日韩欧美1区| 91精品国产自产在线丝袜啪| 超碰在线99| 日本色综合中文字幕| 亚洲精品国产偷自在线观看| 国产精品久久久久9999高清| 不卡一区综合视频| 久久伊人久久| 四虎精品一区二区免费| 久久精品国产68国产精品亚洲| 婷婷精品在线| 欧美天堂视频| 麻豆精品av| 欧美一级网址| 亚洲综合激情在线| 一区免费视频| 欧美搞黄网站| 日本蜜桃在线观看视频| 日韩精品亚洲专区| 久久亚洲二区| 午夜电影亚洲| 特黄特色欧美大片| 国产 日韩 欧美一区| 精品国产18久久久久久二百| 亚洲97av| 天堂va欧美ⅴa亚洲va一国产| 日本黄色精品| 久久精品三级| 久久精品女人| 精品国产不卡一区二区| 国产精品亚洲欧美日韩一区在线| 免费的成人av| 欧美日韩在线精品一区二区三区激情综合| 一区在线免费观看| 亚洲一区二区三区高清不卡| aⅴ色国产欧美| 快she精品国产999| 视频一区日韩精品| 欧美亚洲人成在线| 久久久久九九精品影院| 成人污污视频| 国产不卡一区| 黄色av一区| 日本不卡一区二区| 久久精品毛片| 婷婷成人综合| 91麻豆精品激情在线观看最新 | 亚洲深夜视频| 欧美在线亚洲综合一区| 亚洲精品乱码| 久久精品国产亚洲一区二区三区| 日韩成人a**站| 日韩中文在线播放| 久久不射网站| 国产精品nxnn| 亚洲婷婷免费| 国产午夜精品一区在线观看| 久久精品毛片| 国产精品嫩草99av在线| 欧美日韩一区二区高清| 亚洲欧洲高清| 日韩手机在线| 亚洲性视频h| 日韩精品看片| 国产亚洲字幕| 亚洲一级二级| 久久精品亚洲一区二区| 精品三区视频| 麻豆精品网站| 国产成人免费| 日韩高清在线观看一区二区| 日韩在线不卡| 欧美国产极品| 一二三区精品| 视频在线在亚洲| 日韩精品欧美| 激情黄产视频在线免费观看| 国产日韩一区| 国产亚洲第一伦理第一区| 另类亚洲自拍| 性欧美69xoxoxoxo| 国产伊人精品| 捆绑调教美女网站视频一区| 欧美精品一二| 天堂av在线| 免费在线观看一区二区三区| 极品日韩av| 国产美女高潮在线| 国产精品毛片在线| 神马久久午夜| 国产精品欧美一区二区三区不卡| 欧美成人亚洲| 91综合网人人| 欧美三区不卡|