文章詳情頁
原創(chuàng)-關(guān)于java中的對(duì)象序列化
瀏覽:27日期:2024-07-02 08:44:05
內(nèi)容: java對(duì)象序列化機(jī)制一般來講有兩種用途:1.需要將對(duì)象的狀態(tài)保存到文件中,而后能夠通過讀入對(duì)象狀態(tài)來重新構(gòu)造對(duì)象,恢復(fù)程序狀態(tài)2.使用套接字在網(wǎng)絡(luò)上傳送對(duì)象的程序來說,是很有用的。 我們通過讓類實(shí)現(xiàn)java.io.Serializable 接口可以將類序列化。這個(gè)接口是一個(gè)制造者(marker)接口。也就是說,對(duì)于要實(shí)現(xiàn)它的類來說,該接口不需要實(shí)現(xiàn)任何方法。它主要用來通知Java虛擬機(jī)(JVM),需要將一個(gè)對(duì)象序列化。 對(duì)于這個(gè),有幾點(diǎn)我們需要明確:1.并非所有類都可以序列化,在cmd下,我們輸入serialver java.net.socket,可以得到socket是否可序列化的信息,實(shí)際上socket是不可序列化的。2.java有很多基礎(chǔ)類已經(jīng)實(shí)現(xiàn)了serializable接口,比如string,vector等。但是比如hashtable就沒有實(shí)現(xiàn)serializable接口。 將對(duì)象讀出或者寫入流的主要類有兩個(gè): ObjectOutputStream與ObjectInputStream 。ObjectOutputStream 提供用來將對(duì)象寫入輸出流的writeObject方法, ObjectInputStream提供從輸入流中讀出對(duì)象的readObject方法。使用這些方法的對(duì)象必須已經(jīng)被序列化的。也就是說,必須已經(jīng)實(shí)現(xiàn)Serializable接口。如果你想writeobject一個(gè)hashtable對(duì)象,那么,會(huì)得到一個(gè)異常。 下面舉個(gè)例子: import java.io.*;public class testser implements Serializable { public int ii; testser() { } testser( int param ) { ii = param; }}testser是一個(gè)實(shí)現(xiàn)了serializable接口的類。 讀寫這個(gè)序列化過的類:import java.io.*;public class Ser { private static String datafile; datafile='ser.data'; public static void main( String[] argv ) { System.out.println( 'Java Serialization Demo.' ); SerData data; try { ObjectInputStream in = new ObjectInputStream( new FileInputStream( datafile )); data = (SerData) in.readObject(); in.close(); } catch (Exception e) { data = new testser(); } System.out.println( 'Original data: ii = ' + data.ii ); data.ii++; try { ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream( datafile ) ); out.writeObject( data ); out.flush(); out.close(); } catch (Exception e) { System.out.println( e ); } }}還有可以通過套接字傳遞序列化對(duì)象,大概類似。看到這里或許很多人都會(huì)有個(gè)疑問,是否所有的對(duì)象都可以序列化呢?當(dāng)然是不可以的了,至于為什么不可以,那就有很多原因了,比如:1.安全方面的原因,比如一個(gè)對(duì)象擁有private,public等field,對(duì)于一個(gè)要傳輸?shù)膶?duì)象,比如寫到文件,或者進(jìn)行rmi傳輸?shù)鹊?在序列化進(jìn)行傳輸?shù)倪^程中,這個(gè)對(duì)象的private等域是不受保護(hù)的.2.資源分配方面的原因,比如socket,thread類,如果可以序列化,進(jìn)行傳輸或者保存,也無法對(duì)他們進(jìn)行重新的資源分配,而且,也是沒有必要這樣實(shí)現(xiàn). 【matrix 原創(chuàng)】 轉(zhuǎn)載請(qǐng)注明來自Matrix.org.cn Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
標(biāo)簽:
Java
相關(guān)文章:
1. ASP中實(shí)現(xiàn)字符部位類似.NET里String對(duì)象的PadLeft和PadRight函數(shù)2. 詳解基于python的全局與局部序列比對(duì)的實(shí)現(xiàn)(DNA)3. django 利用Q對(duì)象與F對(duì)象進(jìn)行查詢的實(shí)現(xiàn)4. ASP基礎(chǔ)知識(shí)Command對(duì)象講解5. Django中Q查詢及Q()對(duì)象 F查詢及F()對(duì)象用法6. 怎樣才能用js生成xmldom對(duì)象,并且在firefox中也實(shí)現(xiàn)xml數(shù)據(jù)島?7. Python過濾序列元素的方法8. PHP 對(duì)象繼承原理與簡(jiǎn)單用法示例9. 解決SpringBoot在后臺(tái)接收前臺(tái)傳遞對(duì)象方式的問題10. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對(duì)象Application和Session)
排行榜
