為什么要實現(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)被序列化或逆序列化。
使用情況:當遍歷一個圖形時,可能會遇到不支持可序列化接口的對象。在此情況下,將拋出NotSerializableException,并將標識不可序列化對象的類。在序列化和反序列化過程中需要特殊處理的類必須使用下列準確簽名來實現(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方法使用流中的信息來分配流中通過當前對象中相應(yīng)命名字段保存的對象的字段。這用于處理類發(fā)展后需要添加新字段的情形。
將對象寫入流時需要指定要使用的替代對象的可序列化類,應(yīng)使用準確的簽名來實現(xiàn)此特殊方法:ANY-ACCESS-MODIFIERObjectwriteReplace()throwsObjectStreamException;此writeReplace方法將由序列化調(diào)用,前提是如果此方法存在,而且它可以通過被序列化對象的類中定義的一個方法訪問。因此,該方法可以擁有私有(private)、受保護的(protected)和包私有(package-private)訪問。子類對此方法的訪問遵循java訪問規(guī)則。
在從流中讀取類的一個實例時需要指定替代的類應(yīng)使用的準確簽名來實現(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)被序列化或逆序列化。序列化類的所有子類本身都是可序列化的。這個序列化接口沒有任何方法和域,僅用于標識序列化的語意。
允許非序列化類的子類型序列化,子類型可以假定負責(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)了用序化類的作用,即用來傳送類的對象。當一個JavaBean在構(gòu)造工具內(nèi)被用戶化,并與其它Bean建立連接之后,它的所有狀態(tài)都應(yīng)當可被保存,下一次被load進構(gòu)造工具內(nèi)或在運行時,就應(yī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)當是被保存的,也可有選擇地保存內(nèi)部狀態(tài)。
Bean開發(fā)者在修改軟件時,可以添加字段,移走對其它類的引用,改變一個字段的private、protected或public狀態(tài),這些都不影響類的存儲結(jié)構(gòu)關(guān)系。然而,當從類中刪除一個字段,改變一個變量在類體系中的位置,把某個字段改成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只是為了標注該對象是可被序列化的,然后使用一個輸出流(如: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é)碼,當在其他位置讀到這些字節(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