หลีกเลี่ยงการดาวน์โหลดที่ไม่ได้เพิ่มประสิทธิภาพ

ผู้ใช้แอปบางรายของคุณมีสิทธิ์เข้าถึงอินเทอร์เน็ตเป็นครั้งคราวหรือมีข้อจำกัด เกี่ยวกับปริมาณข้อมูลที่ดาวน์โหลดลงในอุปกรณ์ได้ คุณสามารถ กระตุ้นให้ผู้ใช้โต้ตอบกับแอปบ่อยขึ้นได้โดยการลดปริมาณ ข้อมูลที่แอปต้องดาวน์โหลด

วิธีพื้นฐานที่สุดในการลดการดาวน์โหลดคือการดาวน์โหลดเฉพาะสิ่งที่คุณต้องการ ในแง่ของข้อมูล นั่นหมายถึงการติดตั้งใช้งาน 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 ออกจากข้อมูลหรือทรัพยากรที่เฉพาะเจาะจง ที่เก็บ อาจดึงข้อมูลจากแหล่งต่างๆ ในตอนแรก เช่น บริการเว็บระยะไกล แต่จะให้ข้อมูลเวอร์ชันที่แคชไว้แก่ผู้โทรในการโทรครั้งต่อๆ ไป เลเยอร์การเปลี่ยนเส้นทางนี้ช่วยให้คุณใช้กลยุทธ์การแคชที่มีประสิทธิภาพซึ่ง เฉพาะเจาะจงกับแอปของคุณได้ ดูข้อมูลเพิ่มเติมเกี่ยวกับการใช้รูปแบบ Repository ภายในแอปได้ที่คำแนะนำเกี่ยวกับสถาปัตยกรรมของแอป