為什么要實現(xiàn)serializable接口作用

為什么要實現(xiàn)serializable接口作用

最重要的兩個原因是:1、將對象的狀態(tài)保存在存儲媒體中以便可以在以后重新創(chuàng)建出完全相同的副本;2、按值將對象從一個應(yīng)用程序域發(fā)送至另一個應(yīng)用程序域。實現(xiàn)serializable接口的作用是就是可以把對象存到字節(jié)流,然后可以恢復(fù)。

所以你想如果你的對象沒實現(xiàn)序列化怎么才能進行**傳輸呢,要**傳輸就得轉(zhuǎn)為字節(jié)流,所以在分布式應(yīng)用中,你就得實現(xiàn)序列化,如果你不需要分布式應(yīng)用,那就沒那個必要實現(xiàn)序列化。

某些java類為什么要實現(xiàn)Serializable接口

Serializable接口是啟用其序列化功能的接口。實現(xiàn)java.io.Serializable接口的類是可序列化的。

沒有實現(xiàn)此接口的類將不能使它們的任一狀態(tài)被序列化或逆序列化。

使用情況:當(dāng)遍歷一個圖形時,可能會遇到不支持可序列化接口的對象。在此情況下,將拋出NotSerializableException,并將標(biāo)識不可序列化對象的類。在序列化和反序列化過程中需要特殊處理的類必須使用下列準(zhǔn)確簽名來實現(xiàn)特殊方法:privatevoidwriteObject(java.io.ObjectOutputStreamout)throwsIOExceptionprivatevoidreadObject(java.io.ObjectInputStreamin)throwsIOException,ClassNotFoundException;writeObject方法負責(zé)寫入特定類的對象的狀態(tài),以便相應(yīng)的readObject方法可以還原它。通過調(diào)用out.defaultWriteObject可以調(diào)用保存Object的字段的默認機制。

該方法本身不需要涉及屬于其超類或子類的狀態(tài)。狀態(tài)是通過使用writeObject方法或使用DataOutput支持的用于基本數(shù)據(jù)類型的方法將各個字段寫入ObjectOutputStream來保存的。readObject方法負責(zé)從流中讀取并還原類字段。

它可以調(diào)用in.defaultReadObject來調(diào)用默認機制,以還原對象的非靜態(tài)和非瞬態(tài)字段。defaultReadObject方法使用流中的信息來分配流中通過當(dāng)前對象中相應(yīng)命名字段保存的對象的字段。這用于處理類發(fā)展后需要添加新字段的情形。

將對象寫入流時需要指定要使用的替代對象的可序列化類,應(yīng)使用準(zhǔn)確的簽名來實現(xiàn)此特殊方法:ANY-ACCESS-MODIFIERObjectwriteReplace()throwsObjectStreamException;此writeReplace方法將由序列化調(diào)用,前提是如果此方法存在,而且它可以通過被序列化對象的類中定義的一個方法訪問。因此,該方法可以擁有私有(private)、受保護的(protected)和包私有(package-private)訪問。子類對此方法的訪問遵循java訪問規(guī)則。

在從流中讀取類的一個實例時需要指定替代的類應(yīng)使用的準(zhǔn)確簽名來實現(xiàn)此特殊方法。ANY-ACCESS-MODIFIERObjectreadResolve()throwsObjectStreamException;此readResolve方法遵循與writeReplace相同的調(diào)用規(guī)則和訪問規(guī)則。序列化運行時使用一個稱為serialVersionUID的版本號與每個可序列化類相關(guān)聯(lián),該序列號在反序列化過程中用于驗證序列化對象的發(fā)送者和接收者是否為該對象加載了與序列化兼容的類。如果接收者加載的該對象的類的serialVersionUID與對應(yīng)的發(fā)送者的類的版本號不同,則反序列化將會導(dǎo)致InvalidClassException。

可序列化類可以通過聲明名為\”serialVersionUID\”的字段(該字段必須是靜態(tài)(static)、最終(final)的long型字段)顯式聲明其自己的serialVersionUID:ANY-ACCESS-MODIFIERstaticfinallongserialVersionUID=42L;如果可序列化類未顯式聲明serialVersionUID,則序列化運行時將基于該類的各個方面計算該類的默認serialVersionUID值,如“Java(TM)對象序列化規(guī)范”中所述。不過,強烈建議所有可序列化類都顯式聲明serialVersionUID值,原因計算默認的serialVersionUID對類的詳細信息具有較高的敏感性,根據(jù)編譯器實現(xiàn)的不同可能千差萬別,這樣在反序列化過程中可能會導(dǎo)致意外的InvalidClassException。因此,為保證serialVersionUID值跨不同java編譯器實現(xiàn)的一致性,序列化類必須聲明一個明確的serialVersionUID值。還強烈建議使用private修改器顯示聲明serialVersionUID(如果可能),原因是這種聲明僅應(yīng)用于立即聲明類–serialVersionUID字段作為繼承成員沒有用處。

————————–實現(xiàn)java.io.Serializable接口的類是可序列化的。沒有實現(xiàn)此接口的類將不能使它們的任一狀態(tài)被序列化或逆序列化。序列化類的所有子類本身都是可序列化的。這個序列化接口沒有任何方法和域,僅用于標(biāo)識序列化的語意。

允許非序列化類的子類型序列化,子類型可以假定負責(zé)保存和恢復(fù)父類型的公有的、保護的和(如果可訪問)包的域的狀態(tài)。只要該類(即父類)有一個無參構(gòu)造子,可初始化它的狀態(tài),那么子類型就可承擔(dān)上述職責(zé);如果該類沒有無參構(gòu)造函數(shù),在這種情況下申明一個可序列化的類是一個錯誤。此錯誤將在運行時被檢測。

例如:Integer實現(xiàn)了Serializable,所以可以把一個Integer的對象用IO寫到文件里,之后再可以從文件里讀出,如你開始寫入的時候那個對象的intValue()是5的話,那讀出來之后也是5。這一點體現(xiàn)了用序化類的作用,即用來傳送類的對象。當(dāng)一個JavaBean在構(gòu)造工具內(nèi)被用戶化,并與其它Bean建立連接之后,它的所有狀態(tài)都應(yīng)當(dāng)可被保存,下一次被load進構(gòu)造工具內(nèi)或在運行時,就應(yīng)當(dāng)是上一次修改完的信息。

為了能做到這一點,要把Bean的某些字段的信息保存下來,在定義Bean時要使它實現(xiàn)Java.io.Serializable接口。例如:publicclassButtonimplementsJava.io.Serializable{……}實現(xiàn)了序列化接口的Bean中字段的信息將被自動保存。若不想保存某些字(這里的Bean中字段的信息將被自動保存是什么意思?這個自動保存是怎么實現(xiàn)的?)段的信息則可在這些字段前冠以transient或static關(guān)鍵字,transient和static變量的信息是不可被保存的。通常,一個Bean所有公開出來的屬性都應(yīng)當(dāng)是被保存的,也可有選擇地保存內(nèi)部狀態(tài)。

Bean開發(fā)者在修改軟件時,可以添加字段,移走對其它類的引用,改變一個字段的private、protected或public狀態(tài),這些都不影響類的存儲結(jié)構(gòu)關(guān)系。然而,當(dāng)從類中刪除一個字段,改變一個變量在類體系中的位置,把某個字段改成transient/static,或原來是transient/static,現(xiàn)改為別的特性時,都將引起存儲關(guān)系的變化。所謂的Serializable,就是java提供的通用數(shù)據(jù)保存和讀取的接口。

至于從什么地方讀出來和保存到哪里去都被隱藏在函數(shù)參數(shù)的背后了。這樣子,任何類型只要實現(xiàn)了Serializable接口,就可以被保存到文件中,或者作為數(shù)據(jù)流通過**發(fā)送到別的地方。也可以用管道來傳輸?shù)较到y(tǒng)的其他程序中。這樣子極大的簡化了類的設(shè)計。

只要設(shè)計一個保存一個讀取功能就能解決上面說得所有問題。

java序列化為什么要實現(xiàn)serializable

不一定要 根據(jù)需求 序列化就是一種用來處理對象流的機制,所謂對象流也就是將對象的內(nèi)容進行流化??梢詫α骰蟮膶ο筮M行讀寫操作,也可將流化后的對象傳輸于**之間。

序列化是為了解決在對對象流進行讀寫操作時所引發(fā)的問題。

序列化的實現(xiàn):將需要被序列化的類實現(xiàn)Serializable接口,該接口沒有需要實現(xiàn)的方法,implements Serializable只是為了標(biāo)注該對象是可被序列化的,然后使用一個輸出流(如:FileOutputStream)來構(gòu)造一個ObjectOutputStream(對象流)對象,接著,使用ObjectOutputStream對象的writeObject(Object obj)方法就可以將參數(shù)為obj的對象寫出(即保存其狀態(tài)),要恢復(fù)的話則用輸入流。 序列化:序列化是將對象轉(zhuǎn)換為容易傳輸?shù)母袷降倪^程。例如,可以序列化一個對象,然后使用 HTTP 通過 Internet 在客戶端和服務(wù)器之間傳輸該對象。在另一端,反序列化將從該流重新構(gòu)造對象。

百科是對象**化的一種機制。 確切的說應(yīng)該是對象的序列化,一般程序在運行時,產(chǎn)生對象,這些對象隨著程序的停止運行而消失,但如果我們想把某些對象(因為是對象,所以有各自不同的特性)保存下來,在程序終止運行后,這些對象仍然存在,可以在程序再次運行時讀取這些對象的值,或者在其他程序中利用這些保存下來的對象。這種情況下就要用到對象的序列化。

只有序列化的對象才可以存儲在存儲設(shè)備上。為了對象的序列化而需要繼承的接口也只是一個象征性的接口而已,也就是說繼承這個接口說明這個對象可以被序列化了,沒有其他的目的。之所以需要對象序列化,是因為有時候?qū)ο笮枰?*上傳輸,傳輸?shù)臅r候需要這種序列化處理,從服務(wù)器硬盤上把序列化的對象取出,然后通過**傳到客戶端,再由客戶端把序列化的對象讀入內(nèi)存,執(zhí)行相應(yīng)的處理。

對象序列化是java的一個特征,通過該特征可以將對象寫作一組字節(jié)碼,當(dāng)在其他位置讀到這些字節(jié)碼時,可以依此創(chuàng)建一個新的對象,而且新對象的狀態(tài)與原對象完全相同。為了實現(xiàn)對象序列化,要求必須能夠訪問類的私有變量,從而保證對象狀態(tài)能夠正確的得以保存和恢復(fù)。相應(yīng)的,對象序列化API能夠在對象重建時,將這些值還原給私有的數(shù)據(jù)成員。

這是對java語言訪問權(quán)限的挑戰(zhàn)。通常用在服務(wù)器客戶端的對象交換上面,另外就是在本機的存儲。 對象序列化的最主要的用處就是在傳遞,和保存對象(object)的時候,保證對象的完整性和可傳遞性。

javabean為什么一定要實現(xiàn)serializable接口

ser