簡(jiǎn)介
在日常 iOS 開(kāi)發(fā)中,我們都會(huì)接觸到數(shù)據(jù)持久化接口,如用于保存用戶偏好數(shù)據(jù)的 NSUserDefaults
,增刪文件的 FileManager
,以及操作結(jié)構(gòu)化數(shù)據(jù)的數(shù)據(jù)庫(kù)技術(shù) Core Data。這些數(shù)據(jù)在本地的保存都是按照 iOS 的文件系統(tǒng)的規(guī)則存放在對(duì)應(yīng)的目錄中。這篇文章目的是記錄我在閱讀完蘋果文檔后得到的一些要點(diǎn)概要。
沙盒文件系統(tǒng)
每一個(gè) app 都有各自獨(dú)立的沙盒(sandbox)容器,容納了 app bundle、數(shù)據(jù)儲(chǔ)存容器以及 icloud 儲(chǔ)存容器。這樣設(shè)計(jì)的好處是安全:既可以隔絕其他 app 非法讀寫(xiě)自己的數(shù)據(jù),也防止了自己的文件操作對(duì)系統(tǒng)其他地方有干涉。
既然沙盒里面也做了不同目錄的功能分類,下面來(lái)簡(jiǎn)明了解下各自的作用:
MyApp.app
就是平時(shí)編譯打包出來(lái)的 app bundle,包括 app 的可執(zhí)行文件以及運(yùn)行所需的資源文件。在運(yùn)行時(shí),我們不能對(duì)此目錄進(jìn)行寫(xiě)入。蘋果在安裝 app 時(shí)會(huì)對(duì) bundle 進(jìn)行簽名,之后每次啟動(dòng) app 時(shí)會(huì)先驗(yàn)證簽名,如果驗(yàn)證失敗就無(wú)法啟動(dòng)。因?yàn)閷?xiě)入操作會(huì)改變簽名,因此寫(xiě)入后 app 就無(wú)法再啟動(dòng)。
Documents/
會(huì)被 iCloud 同步或 iTunes 備份的目錄。蘋果建議這個(gè)目錄用來(lái)存放能夠暴露給用戶的文件——用戶在使用 app 過(guò)程中可以創(chuàng)建和修改的文件。例如繪圖應(yīng)用里用戶創(chuàng)建的畫(huà)板文件,日志應(yīng)用里創(chuàng)建的文檔。
另外,系統(tǒng)還可能生成 Documents/Inbox/ 目錄,用于保存來(lái)自其他 app 或者 UIDocumentInteractionController
打開(kāi)的文件。例如郵件附件,如果你的 app 可以處理附件的文件格式,
打開(kāi)附件時(shí)就會(huì)被復(fù)制到 Documents/Inbox/ 下。要注意的是,用戶可以讀取或者刪除此目錄下的文件,但不可以修改或者創(chuàng)建。因此如果用戶需要修改,需要先行把文件復(fù)制到其他可行的目錄下。
Library/
同樣是會(huì)被 iCloud 同步或 iTunes 備份的目錄(除了 Caches 子目錄)。區(qū)別在于蘋果建議這個(gè)目錄存放那些用于支持應(yīng)用運(yùn)行而同時(shí)不應(yīng)該暴露給用戶的文件。根據(jù)用途,蘋果建議放在不同子目錄下:
Library/Application Support/
存放支撐 app 正常功能模塊運(yùn)作的文件,如運(yùn)行日志,配置文件,模板,bundle 或 Documents/Inbox/ 修改過(guò)的文件等。蘋果建議使用公司或應(yīng)用的倒寫(xiě)域名作為子文件夾存放資料。
Library/Caches/
存放 app 的暫存文件。這個(gè)目錄的文件不會(huì)被 iCloud 同步或 iTunes 備份,適合存放可以從服務(wù)器上重新下載的數(shù)據(jù),如音樂(lè)應(yīng)用的本地歌曲儲(chǔ)存。要注意的是,在設(shè)備還原時(shí),系統(tǒng)會(huì)清空此目錄;而在設(shè)備儲(chǔ)存容量不足時(shí),系統(tǒng)在少數(shù)情況里,在 app 沒(méi)運(yùn)行的情況下刪除此目錄。
Library/Preferences/
存放 app 的偏好文件,默認(rèn)情況下是使用 NSUserDefaults
產(chǎn)生的 plist 文件。app 不應(yīng)該自行在此目錄下創(chuàng)建文件,而應(yīng)該通過(guò) NSUserDefaults
來(lái)讀寫(xiě)偏好。
tmp/
用來(lái)存放生命周期更短的臨時(shí)文件。系統(tǒng)在 app 進(jìn)程被停掉時(shí)很有可能會(huì)清空目錄,因此只適合用來(lái)存放只在 app 當(dāng)前運(yùn)行進(jìn)程下用到的文件。顯然,此目錄不會(huì)被 iCloud 同步或 iTunes 備份。
后記
筆記很簡(jiǎn)略,但可以用作對(duì)文檔所述要點(diǎn)的歸納整理。對(duì)系統(tǒng)默認(rèn)目錄的特性了解,有利于在開(kāi)發(fā)過(guò)程中需要進(jìn)行數(shù)據(jù)持久化時(shí)心中有數(shù),做出合理的決定。