淺談Java序列化和hessian序列化的差異
在遠(yuǎn)程調(diào)用中,需要把參數(shù)和返回值通過(guò)網(wǎng)絡(luò)傳輸,這個(gè)使用就要用到序列化將對(duì)象轉(zhuǎn)變成字節(jié)流,從一端到另一端之后再反序列化回來(lái)變成對(duì)象。
既然前面有一篇提到了hessian,這里就簡(jiǎn)單講講Java序列化和hessian序列化的區(qū)別。
首先,hessian序列化比Java序列化高效很多,而且生成的字節(jié)流也要短很多。但相對(duì)來(lái)說(shuō)沒(méi)有Java序列化可靠,而且也不如Java序列化支持的全面。而之所以會(huì)出現(xiàn)這樣的區(qū)別,則要從它們的實(shí)現(xiàn)方式來(lái)看。
先說(shuō)Java序列化,具體工作原理就不說(shuō)了,Java序列化會(huì)把要序列化的對(duì)象類的元數(shù)據(jù)和業(yè)務(wù)數(shù)據(jù)全部序列化從字節(jié)流,而且是把整個(gè)繼承關(guān)系上的東西全部序列化了。它序列化出來(lái)的字節(jié)流是對(duì)那個(gè)對(duì)象結(jié)構(gòu)到內(nèi)容的完全描述,包含所有的信息,因此效率較低而且字節(jié)流比較大。但是由于確實(shí)是序列化了所有內(nèi)容,所以可以說(shuō)什么都可以傳輸,因此也更可用和可靠。
而hessian序列化,它的實(shí)現(xiàn)機(jī)制是著重于數(shù)據(jù),附帶簡(jiǎn)單的類型信息的方法。就像Integer a = 1,hessian會(huì)序列化成I 1這樣的流,I表示int or Integer,1就是數(shù)據(jù)內(nèi)容。而對(duì)于復(fù)雜對(duì)象,通過(guò)Java的反射機(jī)制,hessian把對(duì)象所有的屬性當(dāng)成一個(gè)Map來(lái)序列化,產(chǎn)生類似M className propertyName1 I 1 propertyName S stringValue(大概如此,確切的忘了)這樣的流,包含了基本的類型描述和數(shù)據(jù)內(nèi)容。而在序列化過(guò)程中,如果一個(gè)對(duì)象之前出現(xiàn)過(guò),hessian會(huì)直接插入一個(gè)R index這樣的塊來(lái)表示一個(gè)引用位置,從而省去再次序列化和反序列化的時(shí)間。這樣做的代價(jià)就是hessian需要對(duì)不同的類型進(jìn)行不同的處理(因此hessian直接偷懶不支持short),而且遇到某些特殊對(duì)象還要做特殊的處理(比如StackTraceElement)。而且同時(shí)因?yàn)椴](méi)有深入到實(shí)現(xiàn)內(nèi)部去進(jìn)行序列化,所以在某些場(chǎng)合會(huì)發(fā)生一定的不一致,比如通過(guò)Collections.synchronizedMap得到的map。
總結(jié)
以上就是本文關(guān)于Java序列化和hessian序列化的差異的全部?jī)?nèi)容,希望對(duì)大家有所幫助。
相關(guān)文章
解決mybatis-plus新增數(shù)據(jù)自增ID變無(wú)序問(wèn)題
這篇文章主要介紹了解決mybatis-plus新增數(shù)據(jù)自增ID變無(wú)序問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。2023-07-07Java中BeanUtils.copyProperties()詳解及應(yīng)用場(chǎng)景
BeanUtils.copyProperties()是Apache?Commons?BeanUtils提供的方法,用于Java對(duì)象間屬性的復(fù)制,特別適用于DTO、VO和Entity之間的數(shù)據(jù)傳遞,這篇文章主要介紹了Java中BeanUtils.copyProperties()詳解及應(yīng)用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下2024-09-09Spring核心容器之Bean創(chuàng)建過(guò)程詳解
這篇文章主要介紹了Spring核心容器之Bean創(chuàng)建過(guò)程詳解,獲取?Bean?的方法是?getBean,其來(lái)自?BeanFactory?繼承的AbstractAutowireCapableBeanFactory?抽象類繼承的AbstractBeanFactory?抽象類中,需要的朋友可以參考下2023-11-11基于springboot和redis實(shí)現(xiàn)單點(diǎn)登錄
這篇文章主要為大家詳細(xì)介紹了基于springboot和redis實(shí)現(xiàn)單點(diǎn)登錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06java獲得平臺(tái)相關(guān)的行分隔符和java路徑分隔符的方法
不同系統(tǒng)平臺(tái)下的行分隔符、路徑分隔符等常常不同,如何在Java程序獲取當(dāng)前平臺(tái)的分隔符,以及其他系統(tǒng)相關(guān)的狀態(tài)呢?下面是示例程序,需要的朋友可以參考下2014-02-02Java字符串無(wú)意識(shí)的遞歸過(guò)程解析
這篇文章主要介紹了Java字符串無(wú)意識(shí)的遞歸過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09