出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案(也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問),這個規則把ios系統的封閉性展現的淋漓盡致。
每個沙盒下面都有相似的目錄結構,如下圖所示(出自蘋果官方文件):
每個應用的沙盒目錄都是相似的,主要包含圖中所示的4個目錄:
①存放內容
該目錄包含了應用程式本身的資料,包括資源檔案和可執行檔案等。程式啟動以後,會根據需要從該目錄中動態載入**或資源到記憶體,這裡用到了lazy loading的思想。
②整個目錄是唯讀的
為了防止被篡改,應用在安裝的時候會將該目錄簽名。非越獄情況下,該目錄中內容是無法更改的;在越獄裝置上如果更改了目錄內容,對應的簽名就會被改變,這種情況下蘋果官網描述的後果是應用程式將無法啟動,我沒實踐過。
③是否會被itunes同步
否①存放內容
我們可以將應用程式的資料檔案儲存在該目錄下。不過這些資料型別僅限於不可再生的資料,可再生的資料檔案應該存放在library/cache目錄下。
②是否會被itunes同步
是①存放內容
該目錄用來儲存由外部應用請求當前應用程式開啟的檔案。
比如我們的應用叫a,向系統註冊了幾種可開啟的檔案格式,b應用有乙個a支援的格式的檔案f,並且申請呼叫a開啟f。由於f當前是在b應用的沙盒中,我們知道,沙盒機制是不允許a訪問b沙盒中的檔案,因此蘋果的解決方案是講f拷貝乙份到a應用的documents/inbox目錄下,再讓a開啟f。
②是否會被itunes同步
是①存放內容
蘋果建議用來存放預設設定或其它狀態資訊。
②是否會被itunes同步
是,但是要除了caches子目錄外
①存放內容
主要是快取檔案,使用者使用過程中快取都可以儲存在這個目錄中。前面說過,documents目錄用於儲存不可再生的檔案,那麼這個目錄就用於儲存那些可再生的檔案,比如網路請求的資料。鑑於此,應用程式通常還需要負責刪除這些檔案。
②是否會被itunes同步
否。①存放內容
應用程式的偏好設定檔案。我們使用nsuserdefaults寫的設定資料都會儲存到該目錄下的乙個plist檔案中,這就是所謂的寫道plist中!
②是否會被itunes同步
是①存放內容
各種臨時檔案,儲存應用再次啟動時不需要的檔案。而且,當應用不再需要這些檔案時應該主動將其刪除,因為該目錄下的東西隨時有可能被系統清理掉,目前已知的一種可能清理的原因是系統磁碟儲存空間不足的時候。
②是否會被itunes同步
否nslog(@"%@",nshomedirectory());
輸出結果:
nslog(@"%@",nstemporarydirectory());
輸出結果:
nslog(@"%@",[[nsbundlemainbundle]bundlepath]);
輸出結果:
nsarray *paths = nssearchpathfordirectoriesindomains(nsdocumentdirectory, nsuserdomainmask, yes);
nsstring *path = [pathsobjectatindex:0];
nslog(@"%@",path);
輸出結果:
這裡用到的nssearchpathfordirectoriesindomains方法需要解釋下,其宣告如下:
foundation_export nsarray *nssearchpathfordirectoriesindomains(nssearchpathdirectory directory, nssearchpathdomainmask domainmask, bool expandtilde);
該方法用於返回指定範圍內的指定名稱的目錄的路徑集合。有三個引數:
nssearchpathdirectory型別的enum值,表明我們要搜尋的目錄名稱,比如這裡用nsdocumentdirectory表明我們要搜尋的是documents目錄。如果我們將其換成nscachesdirectory就表示我們搜尋的是library/caches目錄。
nssearchpathdomainmask型別的enum值,指定搜尋範圍,這裡的nsuserdomainmask表示搜尋的範圍限制於當前應用的沙盒目錄。還可以寫成nslocaldomainmask(表示/library)、nsnetworkdomainmask(表示/network)等。
bool值,表示是否展開波浪線~。我們知道在ios中~的全寫形式是/user/username,該值為yes即表示寫成全寫形式,為no就表示直接寫成「~」。
iOS沙盒目錄結構解析
出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案 也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問 這個規則把ios系統的封閉性展現的淋漓盡致。每個沙盒下面都有相似的目錄結構,如下圖所示 出自蘋果官方文件 每個應用的沙盒目錄都是相似的,主要包含圖中所示的4...
iOS沙盒目錄結構解析
出於安全考慮,ios系統的沙盒機制規定每個應用都只能訪問當前沙盒目錄下面的檔案 也有例外,比如系統通訊錄能在使用者授權的情況下被第三方應用訪問 這個規則把ios系統的封閉性展現的淋漓盡致。一 沙盒中幾個主要的目錄 每個沙盒下面都有相似的目錄結構,如下圖所示 出自蘋果官方文件 二 獲取主要目錄路徑的方...
複習iOS沙盒目錄結構解析
存放內容 該目錄包含了應用程式本身的資料,包括資源檔案和可執行檔案等。程式啟動以後,會根據需要從該目錄中動態載入 或資源到記憶體,這裡用到了lazy loading的思想。整個目錄是唯讀的 為了防止被篡改,應用在安裝的時候會將該目錄簽名。非越獄情況下,該目錄中內容是無法更改的 在越獄裝置上如果更改了...