什么叫序列化
序列化是一種處理對(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)題而提出的。