1顶伞、序列化是干什么的廉油? 簡(jiǎn)單說(shuō)就是為了保存在內(nèi)存中的各種對(duì)象的狀態(tài),并且可以把保存的對(duì)象狀態(tài)再讀出來(lái)撩笆。雖然你可以用你自己的各種各樣的方法來(lái)保存Object States捺球,但是Java給你提供一種應(yīng)該比你自己好的保存對(duì)象狀態(tài)的機(jī)制,那就是序列化。
2夕冲、什么情況下需要序列化
a)當(dāng)你想把的內(nèi)存中的對(duì)象保存到一個(gè)文件中或者數(shù)據(jù)庫(kù)中時(shí)候氮兵;
b)當(dāng)你想用套接字在網(wǎng)絡(luò)上傳送對(duì)象的時(shí)候;
c)當(dāng)你想通過(guò)RMI傳輸對(duì)象的時(shí)候歹鱼;
3泣栈、當(dāng)對(duì)一個(gè)對(duì)象實(shí)現(xiàn)序列化時(shí),究竟發(fā)生了什么弥姻?在沒(méi)有序列化前南片,每個(gè)保存在堆(Heap)中的對(duì)象都有相應(yīng)的狀態(tài)(state),即實(shí)例變量(instance ariable)
比如:
Foo myFoo = new Foo();
myFoo .setWidth(37);
myFoo.setHeight(70);
當(dāng)通過(guò)下面的代碼序列化之后蚁阳,MyFoo對(duì)象中的width和Height實(shí)例變量的值(37铃绒,70)都被保存到foo.ser文件中,這樣以后又可以把它 從文件中讀出來(lái)螺捐,重新在堆中創(chuàng)建原來(lái)的對(duì)象颠悬。當(dāng)然保存時(shí)候不僅僅是保存對(duì)象的實(shí)例變量的值,JVM還要保存一些小量信息定血,比如類的類型等以便恢復(fù)原來(lái)的對(duì) 象赔癌。
FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myFoo);
4、實(shí)現(xiàn)序列化(保存到一個(gè)文件)的步驟
a)Make a FileOutputStream
FileOutputStream fs = new FileOutputStream("foo.ser");
b)Make a ObjectOutputStream
ObjectOutputStream os = new ObjectOutputStream(fs);
c)write the object
os.writeObject(myObject1);
os.writeObject(myObject2);
os.writeObject(myObject3);
d) close the ObjectOutputStream
os.close();
5澜沟、舉例說(shuō)明
import java.io.*;
public class Box implements Serializable
{
private int width;
private int height;
public void setWidth(int width){
this.width = width;
}
public void setHeight(int height){
this.height = height;
}
public static void main(String[] args){
Box myBox = new Box();
myBox.setWidth(50);
myBox.setHeight(30);
try{
FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myBox);
os.close();
}catch(Exception ex){
ex.printStackTrace();
}
}
}
6灾票、相關(guān)注意事項(xiàng)
a)當(dāng)一個(gè)父類實(shí)現(xiàn)序列化,子類自動(dòng)實(shí)現(xiàn)序列化茫虽,不需要顯式實(shí)現(xiàn)Serializable接口刊苍;
b)當(dāng)一個(gè)對(duì)象的實(shí)例變量引用其他對(duì)象,序列化該對(duì)象時(shí)也把引用對(duì)象進(jìn)行序列化濒析;
c)并非所有的對(duì)象都可以序列化,至于為什么不可以正什,有很多原因了,
比如
1.安全方面的原因,比如一個(gè)對(duì)象擁有private号杏,public等f(wàn)ield婴氮,對(duì)于一個(gè)要傳輸?shù)膶?duì)象,比如寫到文件,或者進(jìn)行rmi傳輸 等等主经,在序列化進(jìn)行傳輸?shù)倪^(guò)程中荣暮,這個(gè)對(duì)象的private等域是不受保護(hù)的。
2.資源分配方面的原因罩驻,比如socket穗酥,thread類,如果可以序列化惠遏,進(jìn)行傳輸或者保存迷扇,也無(wú)法對(duì)他們進(jìn)行重新的資源分 配,而且爽哎,也是沒(méi)有必要這樣實(shí)現(xiàn)。把一個(gè)對(duì)象完全轉(zhuǎn)成字節(jié)序列器一,方便傳輸课锌。
就像你寄一箱餅干,因?yàn)轶w積太大祈秕,就全壓成粉末緊緊地一包寄出去渺贤,這就是序列化的作用。只不過(guò)JAVA的序列化是可以完全還原的请毛。