持久化
持久化(Persistence),即把內(nèi)存中的對(duì)象保存到可永久保存的存儲(chǔ)設(shè)備中。持久化的主要應(yīng)用是將內(nèi)存中的對(duì)象存儲(chǔ)在關(guān)系型的數(shù)據(jù)庫(kù)中,當(dāng)然也可以存儲(chǔ)在磁盤文件中、XML數(shù)據(jù)文件中等等。
持久化是將程序數(shù)據(jù)在持久狀態(tài)和瞬時(shí)狀態(tài)間轉(zhuǎn)換的機(jī)制。(應(yīng)用與游戲,)
JDBC就是一種持久化機(jī)制。文件IO也是一種持久化機(jī)制。
為什么需要持久化服務(wù)呢?那是由于內(nèi)存本身的缺陷引起的:內(nèi)存掉電后數(shù)據(jù)會(huì)丟失,但有一些對(duì)象是無(wú)論如何都不能丟失的,比如銀行賬號(hào),遺憾的是,人們還無(wú)法保證內(nèi)存永不掉電。
持久化方案可以分為關(guān)系數(shù)據(jù)庫(kù)方案、文件方案、對(duì)象數(shù)據(jù)庫(kù)方案、 xml數(shù)據(jù)庫(kù)方案,目前主流的持久化方案是關(guān)系數(shù)據(jù)庫(kù)方案,關(guān)系數(shù)據(jù)庫(kù)方案不僅解決了并發(fā)的問題,更重要的是,關(guān)系數(shù)據(jù)庫(kù)還提供了持久化服務(wù)之外的價(jià)值:統(tǒng)計(jì)分析功能。
序列化
將對(duì)象的狀態(tài)信息轉(zhuǎn)換為可以存儲(chǔ)或傳輸?shù)男问降倪^程。
在序列化期間,對(duì)象將其當(dāng)前狀態(tài)寫入到臨時(shí)或持久性存儲(chǔ)區(qū)。以后,可以通過從存儲(chǔ)區(qū)中讀取或反序列化對(duì)象的狀態(tài),重新創(chuàng)建該對(duì)象。
目的
1、以某種存儲(chǔ)形式使自定義對(duì)象持久化;
2、將對(duì)象從一個(gè)地方傳遞到另一個(gè)地方。
3、使程序更具維護(hù)性。
當(dāng)兩個(gè)進(jìn)程在進(jìn)行遠(yuǎn)程通信時(shí),彼此可以發(fā)送各種類型的數(shù)據(jù)。無(wú)論是何種類型的數(shù)據(jù),都會(huì)以二進(jìn)制序列的形式在網(wǎng)絡(luò)上傳送。發(fā)送方需要把這個(gè)Java對(duì)象轉(zhuǎn)換為字節(jié)序列,才能在網(wǎng)絡(luò)上傳送;接收方則需要把字節(jié)序列再恢復(fù)為Java對(duì)象。
把Java對(duì)象轉(zhuǎn)換為字節(jié)序列的過程稱為對(duì)象的序列化,又叫串行化
把字節(jié)序列恢復(fù)為Java對(duì)象的過程稱為對(duì)象的反序列化,又叫并行化
對(duì)象的序列化主要有兩種用途:
1) 把對(duì)象的字節(jié)序列永久地保存到硬盤上,通常存放在一個(gè)文件中;
2) 在網(wǎng)絡(luò)上傳送對(duì)象的字節(jié)序列。
關(guān)系
對(duì)象序列化機(jī)制對(duì)于需要將對(duì)象的狀態(tài)保存到文件中,而后能夠通過讀入對(duì)象狀態(tài)來(lái)重新構(gòu)造對(duì)象,恢復(fù)程序狀態(tài),對(duì)象序列化的過程是對(duì)象持久化的方法之一,把對(duì)象保存到文件中。
序列化是為了解決對(duì)象的傳輸問題,傳輸可以在線程之間、進(jìn)程之間、內(nèi)存外存之間、 主機(jī)之間進(jìn)行。
持久化往往依賴于數(shù)據(jù)庫(kù),是為了長(zhǎng)期存儲(chǔ)的。序列化是為了散集和列集做短期存儲(chǔ)和數(shù)據(jù)傳遞的。
如果按照存儲(chǔ)介質(zhì)和生命周期的長(zhǎng)短劃分,所有的數(shù)據(jù)都以兩種形式存在,其中一種是保存于內(nèi)存中的運(yùn)行時(shí)對(duì)象,另一種則是存儲(chǔ)于持久化物理介質(zhì)中的文件,比如數(shù)據(jù)庫(kù)文件等。數(shù)據(jù)的持久化關(guān)注于相同的數(shù)據(jù)在不同形態(tài)數(shù)據(jù)之間的轉(zhuǎn)化,解決的是如何將內(nèi)存對(duì)象持久化存儲(chǔ),以及從物理介質(zhì)中加載數(shù)據(jù)并創(chuàng)建內(nèi)存對(duì)象。
數(shù)據(jù)的持久化是序列化的又一個(gè)典型的應(yīng)用,對(duì)象只有在序列化之后才能進(jìn)行持久化存儲(chǔ),從持久化存儲(chǔ)介質(zhì)加載的數(shù)據(jù)通過反序列化轉(zhuǎn)變成運(yùn)行時(shí)對(duì)象。
Lua序列化實(shí)例
結(jié)果:
標(biāo)簽:嘉峪關(guān) 新余 武漢 張掖 延邊 宜賓 江西 黑龍江
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Lua中的持久化和序列化詳解》,本文關(guān)鍵詞 Lua,中的,持久化,和,序列化,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。