在日常的應(yīng)用開發(fā)中,我們可能需要讓某些對象離開內(nèi)存空間,存儲到物理磁盤,以便長期保存,同時也能減少對內(nèi)存的壓力,而在需要時再將其從磁盤讀取到內(nèi)存,比如將某個特定的對象保存到文件中,隔一段時間后再把它讀取到內(nèi)存中使用,那么該對象就需要實現(xiàn)序列化操作,在Java中可以使用Serializable接口實現(xiàn)對象的序列化,而在android中既可以使用Serializable接口實現(xiàn)對象序列化也可以使用Parcelable接口實現(xiàn)對象序列化,但是在內(nèi)存操作時更傾向于實現(xiàn)Parcelable接口,這樣會使用傳輸效率更高效。接下來我們將分別詳細(xì)地介紹這樣兩種序列化操作。
了解序列化與反序列 序列化 由于存在于內(nèi)存中的對象都是暫時的,無法長期駐存,為了把對象的狀態(tài)保持下來,這時需要把對象寫入到磁盤或者其他介質(zhì)中,這個過程就叫做序列化。
反序列化 反序列化恰恰是序列化的反向操作,也就是說,把已存在在磁盤或者其他介質(zhì)中的對象,反序列化(讀?。┑絻?nèi)存中,以便后續(xù)操作,而這個過程就叫做反序列化。
概括性來說序列化是指將對象實例的狀態(tài)存儲到存儲媒體(磁盤或者其他介質(zhì))的過程。在此過程中,先將對象的公共字段和私有字段以及類的名稱(包括類所在的程序集)轉(zhuǎn)換為字節(jié)流,然后再把字節(jié)流寫入數(shù)據(jù)流。在隨后對對象進行反序列化時,將創(chuàng)建出與原對象完全相同的副本。
實現(xiàn)序列化的必要條件 一個對象要實現(xiàn)序列化操作,該類就必須實現(xiàn)了Serializable接口或者Parcelable接口,其中Serializable接口是在java中的序列化抽象類,而Parcelable接口則是android中特有的序列化接口,在某些情況下,Parcelable接口實現(xiàn)的序列化更為高效,關(guān)于它們的實現(xiàn)案例我們后續(xù)會分析,這里只要清楚知道實現(xiàn)序列化操作時必須實現(xiàn)Serializable接口或者Parcelable接口之一即可。
序列化的應(yīng)用情景 主要有以下情況(但不限于以下情況)
1)內(nèi)存中的對象寫入到硬盤;
2)用套接字在網(wǎng)絡(luò)上傳送對象;
3)通過RMI(RemoteMethodInvoke遠(yuǎn)程方法調(diào)用)傳輸對象;
Serializable Serializable是java提供的一個序列化接口,它是一個空接口,專門為對象提供標(biāo)準(zhǔn)的序列化和反序列化操作,使用Serializable實現(xiàn)類的序列化比較簡單,只要在類聲明中實現(xiàn)Serializable接口即可,同時強烈建議聲明序列化標(biāo)識。
Parcelable 鑒于Serializable在內(nèi)存序列化上開銷比較大,而內(nèi)存資源屬于android系統(tǒng)中的稀有資源(android系統(tǒng)分配給每個應(yīng)用的內(nèi)存開銷都是有限的),為此android中提供了Parcelable接口來實現(xiàn)序列化操作,Parcelable的性能比Serializable好,在內(nèi)存開銷方面較小,所以在內(nèi)存間數(shù)據(jù)傳輸時推薦使用Parcelable,如通過Intent在activity間傳輸數(shù)據(jù),而Parcelable的缺點就使用起來比較麻煩。
網(wǎng)站定制開發(fā)
企業(yè)網(wǎng)站建設(shè)一條龍
找零度飛易網(wǎng)絡(luò)公司-fslingdu所做php
網(wǎng)站建設(shè)方案、
網(wǎng)站設(shè)計、
網(wǎng)站制作由
北京上海深圳龍崗衢州蘭州常州東營南通濟寧桂林淮安煙臺長春無錫天津昆山蘇州合肥貴洛陽昆明天津唐山泉州惠州萬州新鄉(xiāng)商丘臺州哈爾濱太原攝影???/strong>隨州學(xué)校商丘廣東湖南廣西江西海南廣州企業(yè)中小企業(yè)武漢南山羅湖福田虎門肇慶汕尾汕頭廣州佛山成都杭州濟南重慶福州西安廈門昆山沈陽青島徐州鄭州南京寧南寧長沙大連淄博石家莊南昌溫州珠海番禺順德南三水高明中山東莞合肥江門嘉興西寧大良容桂倫教勒流陳村均安杏壇龍江樂從北滘祖廟石灣南莊等地區(qū)企業(yè)網(wǎng)站建設(shè)(廣告)公司提供專業(yè)做網(wǎng)站價格規(guī)劃書及營銷型網(wǎng)站制作,網(wǎng)站建設(shè)基礎(chǔ)知識