java序列化和serialVersionUID的使用方法實(shí)例

我們提供的服務(wù)有:成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、和縣ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的和縣網(wǎng)站制作公司
1、序列化:
序列化可以將一個(gè)java對(duì)象以二進(jìn)制流的方式在網(wǎng)絡(luò)中傳輸并且可以被持久化到數(shù)據(jù)庫(kù)、文件系統(tǒng)中,反序列化則是可以把之前持久化在數(shù)據(jù)庫(kù)或文件系統(tǒng)中的二進(jìn)制數(shù)據(jù)以流的方式讀取出來(lái)重新構(gòu)造成一個(gè)和之前相同內(nèi)容的java對(duì)象。
2、序列化的作用:
第一種:用于將java對(duì)象狀態(tài)儲(chǔ)存起來(lái),通常放到一個(gè)文件中,使下次需要用到的時(shí)候再讀取到它之前的狀態(tài)信息。
第二種:可以讓java對(duì)象在網(wǎng)絡(luò)中傳輸。
3、序列化的實(shí)現(xiàn):
1)、需要序列化的類需要實(shí)現(xiàn)Serializable接口,該接口沒有任何方法,只是標(biāo)示該類對(duì)象可被序列化。
2)、序列化過(guò)程:使用一個(gè)輸出流(如:FileOutputStream)來(lái)構(gòu)造一個(gè)ObjectOutputStream(對(duì)象流)對(duì)象,接著,使用ObjectOutputStream對(duì)象的writeObject(Object obj)方法就可以將參數(shù)為obj的對(duì)象寫出(即保存其狀態(tài))
3)、反序列化過(guò)程:使用一個(gè)輸入流(如:FileInputStream)來(lái)構(gòu)造一個(gè)ObjectInputStream(對(duì)象流)對(duì)象,接著,使用ObjectInputStream對(duì)象的readObject(Object obj)方法就可以將參數(shù)為obj的對(duì)象讀出(即獲取其狀態(tài))
4、靜態(tài)long類型常量serialVersionUID的作用:
如果沒有設(shè)置這個(gè)值,你在序列化一個(gè)對(duì)象之后,改動(dòng)了該類的字段或者方法名之類的,那如果你再反序列化想取出之前的那個(gè)對(duì)象時(shí)就可能會(huì)拋出異常,因?yàn)槟愀膭?dòng)了類中間的信息,serialVersionUID是根據(jù)類名、接口名、成員方法及屬性等來(lái)生成一個(gè)64位的哈希字段,當(dāng)修改后的類去反序列化的時(shí)候發(fā)現(xiàn)該類的serialVersionUID值和之前保存在問(wèn)價(jià)中的serialVersionUID值不一致,所以就會(huì)拋出異常。
而顯示的設(shè)置serialVersionUID值就可以保證版本的兼容性,如果你在類中寫上了這個(gè)值,就算類變動(dòng)了,它反序列化的時(shí)候也能和文件中的原值匹配上。而新增的值則會(huì)設(shè)置成null,刪除的值則不會(huì)顯示。
5、例子:
package com.sxit;
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;
import java.io.Serializable;
public class Serializable01 extends Object implements Serializable{
private static final long serialVersionUID = -1466479389299512377L;
public byte b = 12;
public byte getB() {
return b;
}
public void setB(byte b) {
this.b = b;
}
public static void main(String[] args) {
try {
FileOutputStream fos = new FileOutputStream(new File("E:\\tmp\\demo2.txt"));
ObjectOutputStream os = new ObjectOutputStream(fos);
Serializable01 s = new Serializable01();
os.writeObject(s);
os.flush();
os.close();
FileInputStream fis = new FileInputStream(new File("E:\\tmp\\demo2.txt"));
ObjectInputStream ois = new ObjectInputStream(fis);
Serializable01 s2 = (Serializable01)ois.readObject();
System.out.println(s2.getB());
ois.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
6、序列化特點(diǎn):
1)、如果一個(gè)類可被序列化,其子類也可以,如果該類有父類,則根據(jù)父類是否實(shí)現(xiàn)Serializable接口,實(shí)現(xiàn)了則父類對(duì)象字段可以序列化,沒實(shí)現(xiàn),則父類對(duì)象字段不能被序列化。
2)、聲明為transient類型的成員數(shù)據(jù)不能被序列化。transient代表對(duì)象的臨時(shí)數(shù)據(jù);
3)、當(dāng)一個(gè)對(duì)象的實(shí)例變量引用其他對(duì)象,序列化該對(duì)象時(shí)也把引用對(duì)象進(jìn)行序列化;
以上就是java序列化和serialVersionUID的講解,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
網(wǎng)站名稱:java序列化和serialVersionUID的使用方法實(shí)例
網(wǎng)站鏈接:http://www.chinadenli.net/article10/pecido.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、虛擬主機(jī)、定制開發(fā)、網(wǎng)站策劃、用戶體驗(yàn)、營(yíng)銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)