การติดตามการเรียบเรียง

ร่องรอยมักเป็นแหล่งข้อมูลที่ดีที่สุดเมื่อต้องการตรวจสอบปัญหาด้านประสิทธิภาพเป็นครั้งแรก ซึ่งช่วยให้คุณตั้งสมมติฐานเกี่ยวกับปัญหาและตำแหน่งที่จะเริ่มตรวจสอบ

การติดตามใน Android รองรับการติดตาม 2 ระดับ ได้แก่ การติดตามระบบและการติดตามเมธอด

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

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

โดยค่าเริ่มต้น การติดตามระบบจะไม่รวมฟังก์ชันคอมโพสิเบิลแต่ละรายการ ซึ่งจะแสดงในการติดตามเมธอด

เรากำลังทดสอบฟังก์ชันการติดตามระบบแบบใหม่เพื่อแสดงฟังก์ชันที่ประกอบกันได้ภายในการติดตามระบบ วิธีการนี้ลดการแทรกแซงจากระบบการติดตาม โดยมีการติดตามเมธอดในระดับรายละเอียดในองค์ประกอบ

ตั้งค่าการติดตามองค์ประกอบ

หากต้องการลองใช้การติดตามการจัดองค์ประกอบใหม่ในโปรเจ็กต์ คุณต้องอัปเดตเป็นเวอร์ชันต่อไปนี้เป็นอย่างน้อย

  • Android Studio Flamingo
  • UI ของ Compose: 1.3.0
  • คอมไพเลอร์ของ Compose: 1.3.0

อุปกรณ์หรือโปรแกรมจำลองที่คุณใช้ติดตามต้องอยู่ที่ระดับ API ขั้นต่ำ 30 ด้วย

นอกจากนี้ คุณยังต้องเพิ่มการพึ่งพาใหม่ในเครื่องมือติดตามรันไทม์ของ Compose ดังนี้

implementation("androidx.compose.runtime:runtime-tracing:1.0.0-beta01")

เมื่อใช้การขึ้นต่อกันนี้ เมื่อคุณติดตามระบบที่มีการจัดองค์ประกอบใหม่ คุณจะเห็นฟังก์ชันที่ประกอบกันได้โดยอัตโนมัติ

ทำการติดตามระบบ

หากต้องการติดตามระบบและดูการติดตามการคอมโพสิชันใหม่ในการใช้งาน ให้ทําตามขั้นตอนต่อไปนี้

  1. เปิดเครื่องมือสร้างโปรไฟล์โดยทำดังนี้

    Android Studio - เริ่มการโปรไฟล์
    ภาพที่ 2 Android Studio - เริ่มการโปรไฟล์
  2. คลิกไทม์ไลน์ของ CPU

    เครื่องมือสร้างโปรไฟล์ Android Studio - ไทม์ไลน์ CPU
    รูปที่ 3 เครื่องมือสร้างโปรไฟล์ของ Android Studio - ไทม์ไลน์ CPU
  3. ไปยัง UI ที่คุณต้องการติดตามในแอป จากนั้นเลือก System Trace และ Record

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

    การติดตามของระบบ
    รูปที่ 5 การติดตามระบบ

    การดับเบิลคลิกที่ Composable ในแผนภูมิจะนำคุณไปยังซอร์สโค้ด

  5. นอกจากนี้ คุณยังดูคอมโพสิเบิลในแผนภูมิเปลวไฟพร้อมกับหมายเลขไฟล์และบรรทัดได้ด้วย

    แผนภูมิ Flame Chart
    ภาพที่ 6 แผนภูมิ Flame Chart

ข้อจำกัด

โอเวอร์เฮดของขนาด APK

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

คุณนำสตริงการติดตามออกจากบิลด์เวอร์ชันที่ใช้งานจริงได้โดยเพิ่มกฎ ProGuard ต่อไปนี้

-assumenosideeffects public class androidx.compose.runtime.ComposerKt {

   boolean isTraceInProgress();

   void traceEventStart(int,int,int,java.lang.String);

   void traceEventStart(int,java.lang.String);

   void traceEventEnd();

}

ฟังก์ชันเหล่านี้อาจมีการเปลี่ยนแปลงในอนาคต แต่จะมีการกล่าวถึงการเปลี่ยนแปลงใดๆ ในบันทึกประจำรุ่น "เขียน"

โปรดทราบว่าการใช้งาน APK อย่างต่อเนื่องจะต้องมีค่าใช้จ่ายเกี่ยวกับขนาด APK นั้นรับประกันได้ว่า APK ที่ได้รับการจัดโปรไฟล์นั้นเป็น APK เดียวกับที่ผู้ใช้แอปใช้

การกำหนดเวลาที่แม่นยำ

คุณต้องทําให้แอป profileable และ non-debuggable ตามแอปพลิเคชันที่ใช้โปรไฟล์ได้ เพื่อการจัดโปรไฟล์ที่ถูกต้อง เช่น การทดสอบประสิทธิภาพใดๆ

บันทึกการติดตามจากเทอร์มินัล

คุณสามารถบันทึกการติดตามการคอมโพสิชันจากเทอร์มินัลได้ โดยคุณต้องทำตามขั้นตอนที่ Android Studio มักจะทำให้คุณโดยอัตโนมัติ

เพิ่มการพึ่งพา

ก่อนอื่นให้เพิ่มทรัพยากร Dependency เพิ่มเติมลงในแอป

implementation("androidx.tracing:tracing-perfetto:1.0.0")
implementation("androidx.tracing:tracing-perfetto-binary:1.0.0")

สร้างคำสั่งระเบียน

  1. สร้างคำสั่งระเบียนโดยใช้ใน Perfetto
  2. เพิ่มส่วนแหล่งข้อมูล track_event ด้วยตนเองตามตัวอย่างต่อไปนี้

    adb shell perfetto \
      -c - --txt \
      -o /data/misc/perfetto-traces/trace \
    <<EOF
    buffers: {
        size_kb: 63488
        fill_policy: RING_BUFFER
    }
    buffers: {
        size_kb: 2048
        fill_policy: RING_BUFFER
    }
    data_sources: {
        config {
            name: "track_event"
        }
    }
    duration_ms: 10000
    flush_period_ms: 30000
    incremental_state_config {
        clear_period_ms: 5000
    }
    EOF
    

จับภาพการติดตาม

  1. เปิดแอปและเตรียมส่วนที่ต้องการติดตาม
  2. เปิดใช้การติดตามในแอปโดยการออกการออกอากาศ

    # set app package variable, e.g. com.google.samples.apps.nowinandroid.debug
    # can be found through `adb shell ps -ef` or `adb shell cmd package list packages`
    package=<your app process>
    
    # issue a broadcast to enable tracing
    adb shell am broadcast \
    -a androidx.tracing.perfetto.action.ENABLE_TRACING \
    $package/androidx.tracing.perfetto.TracingReceiver
    
  3. เริ่มใช้คำสั่งบันทึกที่คุณสร้างไว้ก่อนหน้านี้

เปิดการติดตาม

  1. adb pull <location> ร่องรอยจากอุปกรณ์ (ตำแหน่งที่ระบุในคำสั่ง record)

  2. เปิดใน Perfetto

จับภาพการติดตามด้วย Jetpack Macrobenchmark

คุณวัดประสิทธิภาพได้ด้วย Jetpack Macrobenchmark ซึ่งจะให้การติดตามเป็นผลลัพธ์ หากต้องการเปิดใช้การติดตามองค์ประกอบด้วยการเปรียบเทียบมาโคร คุณจะต้องทำดังนี้

  1. เพิ่มข้อกําหนดเพิ่มเติมเหล่านี้ลงในโมดูลการทดสอบ Macrobenchmark

    implementation("androidx.tracing:tracing-perfetto:1.0.0")
    implementation("androidx.tracing:tracing-perfetto-binary:1.0.0")
    
  2. เพิ่มอาร์กิวเมนต์การวัดคุม androidx.benchmark.fullTracing.enable=true ก่อนเรียกใช้การเปรียบเทียบ โปรดดูอาร์กิวเมนต์การใช้เครื่องมือการเปรียบเทียบมาโครสำหรับข้อมูลเพิ่มเติมเกี่ยวกับอาร์กิวเมนต์การใช้เครื่องมือการเปรียบเทียบมาโคร

ความคิดเห็น

เรายินดีรับฟังความคิดเห็นจากคุณเกี่ยวกับฟีเจอร์นี้ ข้อบกพร่องที่คุณพบเกี่ยวกับฟีเจอร์นี้ และคำขอต่างๆ ที่คุณมี คุณสามารถส่งความคิดเห็นถึงเราผ่านเครื่องมือติดตามปัญหา