MMKV的核心原理是將文件MMAP到內(nèi)存中,將新的key/value直接append到內(nèi)存中,如果達(dá)到邊界了,就重整以騰出空間,如果空間還是不夠的話,就直接double內(nèi)存塊。MMKV只會選用最新寫入的key/value作為有效值。
優(yōu)點(diǎn):讀寫效率高,因?yàn)槭侵苯訉憙?nèi)存,不需要進(jìn)行文件讀寫。文件讀寫是由操作系統(tǒng)自行實(shí)現(xiàn)的,不會出現(xiàn)內(nèi)容丟失。支持多進(jìn)程鎖。
缺點(diǎn):初始化的時(shí)候會直接申請一塊內(nèi)存,如果用的key/value不多,就會浪費(fèi)一大塊內(nèi)存。
-
MMKV如何支持多進(jìn)程?
- 去中心化架構(gòu):將文件內(nèi)容通過MMAP映射到每個(gè)訪問進(jìn)程的內(nèi)存塊中。
- 通過對寫指針的更新和定位,實(shí)現(xiàn)內(nèi)容的狀態(tài)同步。
- 通過優(yōu)化和升級文件鎖,給內(nèi)容加上進(jìn)程鎖,保證內(nèi)容的讀寫同步。
MMKV的數(shù)據(jù)序列化使用的是Protocol協(xié)議,將key/value序列化成buffer(內(nèi)存塊)存儲到內(nèi)存中。
參考資料:
https://github.com/Tencent/MMKV/wiki/design
https://github.com/Tencent/MMKV/wiki/android_ipc
https://juejin.cn/post/6844903914119102472