為什么實(shí)現(xiàn)Serializable接口就可以序列化
在探討為什么實(shí)現(xiàn)Serializable接口就可以序列化之前,我們需要了解Java中的對(duì)象序列化是什么。簡(jiǎn)單來(lái)說(shuō),對(duì)象序列化是將對(duì)象的狀態(tài)信息轉(zhuǎn)化為可以存儲(chǔ)或傳輸?shù)男问降倪^(guò)程,該過(guò)程依賴(lài)于Java的I/O流機(jī)制。
Serializable接口是一個(gè)標(biāo)記接口,也就是說(shuō),它沒(méi)有任何方法。那么,我們可能會(huì)問(wèn),沒(méi)有任何方法的接口如何啟動(dòng)這樣一個(gè)復(fù)雜的序列化過(guò)程?實(shí)際上,Serializable接口僅僅是為Java的序列化和反序列化機(jī)制提供一個(gè)“啟動(dòng)器”。當(dāng)一個(gè)類(lèi)實(shí)現(xiàn)了Serializable接口,Java的序列化機(jī)制就會(huì)認(rèn)為這個(gè)類(lèi)的對(duì)象是可以序列化的。
對(duì)象的序列化過(guò)程通常涉及到輸出流(OutputStream)或文件輸出流(FileOutputStream),這兩個(gè)類(lèi)都是Java I/O流機(jī)制的一部分。同時(shí),還會(huì)使用到對(duì)象輸出流(ObjectOutputStream),這個(gè)類(lèi)實(shí)現(xiàn)了把對(duì)象轉(zhuǎn)化為字節(jié)流的操作。
在反序列化過(guò)程中,需要使用到輸入流(InputStream)、文件輸入流(FileInputStream)和對(duì)象輸入流(ObjectInputStream)。這些類(lèi)和接口協(xié)同工作,將字節(jié)流轉(zhuǎn)化回原來(lái)的對(duì)象。
可以看出,實(shí)現(xiàn)Serializable接口并不是使對(duì)象變得可序列化的魔法。而是,它是一個(gè)啟動(dòng)器,提示序列化和反序列化機(jī)制該對(duì)象可以進(jìn)行序列化操作。實(shí)際的工作是由Java I/O流機(jī)制和相關(guān)的類(lèi)完成的。
延伸閱讀
Java中的Externalizable接口
除了Serializable接口外,Java還提供了一個(gè)名為Externalizable的接口,用于控制序列化過(guò)程。Externalizable接口擴(kuò)展了Serializable接口,并添加了兩個(gè)方法:writeExternal()和readExternal()。這兩個(gè)方法提供了一種自定義序列化過(guò)程的機(jī)制,允許開(kāi)發(fā)人員精確地控制哪些字段需要序列化,以及如何進(jìn)行序列化。當(dāng)然,使用Externalizable接口的代價(jià)是需要編寫(xiě)更多的代碼,并需要更深入地理解序列化過(guò)程。