1、序列化是干什么的?
??? ?? 簡(jiǎn)單說就是為了保存在內(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)你想通過RMI傳輸對(duì)象的時(shí)候;
3、當(dāng)對(duì)一個(gè)對(duì)象實(shí)現(xiàn)序列化時(shí),究竟發(fā)生了什么?
??? 在沒有序列化前,每個(gè)保存在堆(Heap)中的對(duì)象都有相應(yīng)的狀態(tài)(state),即實(shí)例變量(instance ariable)比如:
java 代碼
- Foo??myFoo?=?new?Foo();??
- myFoo?.setWidth(37);??
- myFoo.setHeight(70);??
當(dāng) 通過下面的代碼序列化之后,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ì) 象。
java 代碼
- FileOutputStream?fs?=?new?FileOutputStream("foo.ser");??
- ObjectOutputStream?os?=?new?ObjectOutputStream(fs);??
- os.writeObject(myFoo);??
4、實(shí)現(xiàn)序列化(保存到一個(gè)文件)的步驟
a)Make a FileOutputStream??? ?? ?? ?? java 代碼
- FileOutputStream?fs?=?new?FileOutputStream("foo.ser");????
??? ?? b)Make a ObjectOutputStream??? ?? ?? ?
java 代碼
- ObjectOutputStream?os?=??new?ObjectOutputStream(fs);???
??? ?? c)write the object
java 代碼
- os.writeObject(myObject1);??
- os.writeObject(myObject2);??
- os.writeObject(myObject3);??
??? d) close the ObjectOutputStream
java 代碼
- os.close();??
5、舉例說明
java 代碼
- 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ù)倪^程中,這個(gè)對(duì)象的private等域是不受保護(hù)的。
?????? 2. 資源分配方面的原因,比如socket,thread類,如果可以序列化,進(jìn)行傳輸或者保存,也無(wú)法對(duì)他們進(jìn)行重新的資源分? 配,而且,也是沒有必要這樣實(shí)現(xiàn)。
文章來(lái)源:
http://x-spirit.spaces.live.com/Blog/cns!CC0B04AE126337C0!311.entry