為什么要序列化,而不能像在內(nèi)存中那樣把對(duì)象作為參數(shù)直接

什么叫序列化

序列化是一種處理對(duì)象流的機(jī)制——把內(nèi)存中的Java對(duì)象轉(zhuǎn)換成二進(jìn)制流。
對(duì)象流化后,將對(duì)象內(nèi)容保存在磁盤(pán)文件中或作為數(shù)據(jù)流進(jìn)行網(wǎng)絡(luò)傳輸。簡(jiǎn)單來(lái)說(shuō),序列化是將對(duì)象的狀態(tài)信息轉(zhuǎn)換為可以存儲(chǔ)或傳輸?shù)男问降倪^(guò)程。

為什么需要序列化

java對(duì)象序列化后可以很方便的存儲(chǔ)或者在網(wǎng)絡(luò)中傳輸。
從服務(wù)器硬盤(pán)上把序列化的對(duì)象取出,然后通過(guò)網(wǎng)絡(luò)傳到客戶(hù)端,再由客戶(hù)端把序列化的對(duì)象讀入內(nèi)存,執(zhí)行相應(yīng)的處理。

這里首先要確定一件事,內(nèi)存中將對(duì)象作為參數(shù)傳遞其實(shí)只是傳遞對(duì)象的引用(指針)。

就如我們熟知的繼承,并非是將父類(lèi)對(duì)象保存在子類(lèi)對(duì)象中,而是子類(lèi)對(duì)象包含了父類(lèi)的引用。

在Java內(nèi)部,繼承是通過(guò)隱式的組合實(shí)現(xiàn)的。子類(lèi)對(duì)象中會(huì)保存一個(gè)實(shí)例對(duì)象的引用super,引用指向其父類(lèi)。

實(shí)際的方法調(diào)用中,java會(huì)優(yōu)先在當(dāng)前類(lèi)對(duì)象中尋找名稱(chēng)相同的方法,如果沒(méi)有,進(jìn)根據(jù)super引用到父類(lèi)對(duì)象中去尋找,所以,如果父類(lèi)方法在子類(lèi)中得到重寫(xiě),java會(huì)調(diào)用子類(lèi)的方法,而不會(huì)調(diào)用被重寫(xiě)的父類(lèi)方法。

這也是多態(tài)的實(shí)現(xiàn)機(jī)制。

到這里,基本就明白了,內(nèi)存?zhèn)鱽?lái)傳去的都是地址而已,如果直接將其直接存庫(kù),到時(shí)候內(nèi)存又經(jīng)過(guò)刷洗,你從庫(kù)中取出來(lái)的地址無(wú)疑是刻舟求劍。

java的優(yōu)勢(shì)在于跨平臺(tái),尤其在分布式環(huán)境中,傳遞對(duì)象是非常普遍的,既然涉及到了傳輸,勢(shì)必有相應(yīng)的協(xié)議,序列化就是為了解決這個(gè)問(wèn)題而提出的。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容