部分應用程式使用者可能會間歇性地存取網際網路,或無法將大量資訊下載到裝置上。您可以減少應用程式需要下載的資料量,鼓勵使用者更頻繁地與應用程式互動。
減少下載次數最根本的方法,就是只下載所需內容。就資料而言,這表示您必須實作 REST API,以便指定查詢條件,並使用參數 (例如上次更新的時間) 限制傳回的資料。
同樣地,下載圖片時,建議您在伺服器端縮減圖片大小,而非下載在用戶端縮減的完整大小圖片。
快取 HTTP 回應
另一個重要的技巧,就是避免下載重複的資料。您可以使用快取功能,減少重複下載相同資料的可能性。您可以將應用程式的資料和資源快取,為應用程式需要參照的資訊建立本機副本。如果應用程式需要在短時間內多次存取相同資訊,則只需將該資訊下載至快取一次。
為了減少下載的資料總量,請務必盡可能積極快取。請務必將靜態資源快取,包括按需下載的資源 (例如完整大小的圖片),盡可能快取。應將隨選資源分開儲存,以便定期清除隨選快取,管理其大小。
為確保快取功能不會導致應用程式顯示過時的資料,請使用適當的 HTTP 狀態碼和標頭,例如 ETag
和 Last-Modified
標頭。這樣一來,您就能決定何時應重新整理相關內容。例如:
Kotlin
// url represents the website containing the content to place into the cache. val conn: HttpsURLConnection = url.openConnection() as HttpsURLConnection val currentTime: Long = System.currentTimeMillis() val lastModified: Long = conn.getHeaderFieldDate("Last-Modified", currentTime) // lastUpdateTime represents when the cache was last updated. if (lastModified < lastUpdateTime) { // Skip update } else { // Parse update lastUpdateTime = lastModified }
Java
// url represents the website containing the content to place into the cache. HttpsURLConnection conn = (HttpsURLConnection) url.openConnection(); long currentTime = System.currentTimeMillis(); long lastModified = conn.getHeaderFieldDate("Last-Modified", currentTime); // lastUpdateTime represents when the cache was last updated. if (lastModified < lastUpdateTime) { // Skip update } else { // Parse update lastUpdateTime = lastModified; }
您可以設定部分網路程式庫,讓這些狀態碼和標頭自動生效。舉例來說,使用 OkHttp 時,為用戶端設定快取目錄和快取大小,即可讓程式庫使用 HTTP 快取,如以下程式碼範例所示:
Kotlin
val cacheDir = Context.getCacheDir() val cacheSize = 10L * 1024L * 1024L // 10 MiB val client: OkHttpClient = OkHttpClient.Builder() .cache(Cache(cacheDir, cacheSize)) .build()
Java
File cacheDir = Context.getCacheDir(); long cacheSize = 10L * 1024L * 1024L; // 10 MiB OkHttpClient client = new OkHttpClient.Builder() .cache(new Cache(cacheDir, cacheSize)) .build();
設定快取後,您可以直接從本機儲存空間提供已完全快取的 HTTP 要求,而不需要開啟網路連線。條件快取的回應可以從伺服器驗證其新鮮度,省去下載作業的頻寬成本。未快取的回應會儲存在回應快取中,以供日後要求使用。
您可以使用 Context.getExternalCacheDir()
,在未管理的外部快取目錄中快取非機密資料。或者,您也可以使用 Context.getCacheDir()
,將資料快取至受管理的安全應用程式快取。請注意,當系統可用儲存空間不足時,可能會清除這個內部快取。
使用存放區
如要採用更精密的快取方法,請考慮使用 Repository 設計模式。這包括建立自訂類別 (稱為存放區),該類別會針對某些特定資料或資源提供 API 抽象層。存放區可能會一開始從各種來源 (例如遠端網路服務) 擷取資料,但在後續呼叫中,會為呼叫端提供快取版本的資料。這個間接層可讓您提供專屬於應用程式的可靠快取策略。如要進一步瞭解如何在應用程式中使用存放區模式,請參閱「應用程式架構指南」。