Tránh tải xuống khi chưa được tối ưu hoá

Một số người dùng ứng dụng của bạn truy cập Internet không ổn định hoặc bị giới hạn về lượng thông tin mà họ có thể tải xuống thiết bị của mình. Bạn có thể khuyến khích người dùng tương tác với ứng dụng của bạn thường xuyên hơn bằng cách giảm lượng dữ liệu mà ứng dụng cần tải xuống.

Cách cơ bản nhất để giảm số lượt tải xuống là chỉ tải những tệp bạn cần xuống. Về mặt dữ liệu, điều đó có nghĩa là triển khai các API REST cho phép bạn chỉ định tiêu chí truy vấn giới hạn dữ liệu được trả về bằng cách sử dụng các tham số như thời điểm cập nhật gần đây nhất.

Tương tự, khi tải hình ảnh xuống, bạn nên giảm kích thước của hình ảnh phía máy chủ, thay vì tải xuống hình ảnh có kích thước đầy đủ bị giảm trên máy khách.

Lưu phản hồi HTTP vào bộ nhớ đệm

Một kỹ thuật quan trọng khác là tránh tải dữ liệu trùng lặp xuống. Bạn có thể giảm khả năng tải cùng một phần dữ liệu xuống nhiều lần bằng cách sử dụng tính năng lưu vào bộ nhớ đệm. Bằng cách lưu dữ liệu và tài nguyên của ứng dụng vào bộ nhớ đệm, bạn sẽ tạo một bản sao cục bộ của thông tin mà ứng dụng cần tham chiếu. Nếu ứng dụng của bạn cần truy cập vào cùng một thông tin nhiều lần trong một khoảng thời gian ngắn, thì bạn chỉ cần tải thông tin đó xuống bộ nhớ đệm một lần.

Bạn cần lưu vào bộ nhớ đệm nhiều nhất có thể để giảm tổng lượng dữ liệu mà bạn tải xuống. Luôn lưu vào bộ nhớ đệm các tài nguyên tĩnh, bao gồm cả nội dung tải xuống theo yêu cầu, chẳng hạn như hình ảnh kích thước đầy đủ, càng lâu càng tốt. Các tài nguyên theo yêu cầu phải được lưu trữ riêng để bạn có thể thường xuyên xoá bộ nhớ đệm theo yêu cầu nhằm quản lý kích thước của nó.

Để đảm bảo việc lưu vào bộ nhớ đệm không làm cho ứng dụng của bạn hiển thị dữ liệu cũ, hãy sử dụng các tiêu đề và mã trạng thái HTTP thích hợp, chẳng hạn như các tiêu đề ETagLast-Modified. Việc này cho phép bạn xác định thời điểm cần làm mới nội dung liên quan. Ví dụ:

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;
}

Bạn có thể định cấu hình một số thư viện mạng để tự động tuân theo các tiêu đề và mã trạng thái này. Ví dụ: khi sử dụng OkHttp, việc định cấu hình thư mục bộ nhớ đệm và kích thước bộ nhớ đệm cho ứng dụng sẽ cho phép thư viện sử dụng tính năng lưu vào bộ nhớ đệm HTTP, như trong mã mẫu sau đây:

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();

Sau khi định cấu hình bộ nhớ đệm, bạn có thể phân phát các yêu cầu HTTP được lưu hoàn toàn vào bộ nhớ đệm ngay trên bộ nhớ cục bộ, nhờ vậy mà không cần mở kết nối mạng. Các phản hồi được lưu vào bộ nhớ đệm có điều kiện có thể xác thực độ mới của chúng từ máy chủ, giúp loại bỏ chi phí băng thông liên quan đến nội dung tải xuống. Các phản hồi không được lưu vào bộ nhớ đệm sẽ được lưu trữ trong bộ nhớ đệm phản hồi cho các yêu cầu sau này.

Bạn có thể lưu dữ liệu không nhạy cảm vào bộ nhớ đệm trong thư mục bộ nhớ đệm bên ngoài không được quản lý bằng cách sử dụng Context.getExternalCacheDir(). Ngoài ra, bạn có thể lưu dữ liệu vào bộ nhớ đệm trong bộ nhớ đệm của ứng dụng an toàn và được quản lý bằng cách sử dụng Context.getCacheDir(). Xin lưu ý rằng bộ nhớ đệm nội bộ này có thể bị xoá khi hệ thống sắp hết dung lượng lưu trữ còn trống.

Sử dụng kho lưu trữ

Để có phương pháp lưu vào bộ nhớ đệm tinh vi hơn, hãy cân nhắc sử dụng mẫu thiết kế Kho lưu trữ. Việc này bao gồm việc tạo một lớp tuỳ chỉnh, gọi là Kho lưu trữ, cung cấp bản tóm tắt API trên một số dữ liệu hoặc tài nguyên cụ thể. Ban đầu, kho lưu trữ có thể tìm nạp dữ liệu từ nhiều nguồn, chẳng hạn như dịch vụ web từ xa, nhưng cung cấp cho phương thức gọi phiên bản dữ liệu đã lưu vào bộ nhớ đệm trong các lệnh gọi tiếp theo. Lớp gián tiếp này cho phép bạn cung cấp một chiến lược lưu vào bộ nhớ đệm mạnh mẽ dành riêng cho ứng dụng của bạn. Để biết thêm thông tin về cách sử dụng mẫu Kho lưu trữ trong ứng dụng, hãy xem Hướng dẫn về cấu trúc ứng dụng.