การติดตามระบบจะแสดงข้อมูลเกี่ยวกับกระบวนการในระดับระบบเท่านั้น บางครั้งจึงยากที่จะรู้ว่าวิธีการของแอปหรือเกมใด ขณะดําเนินการในช่วงเวลาหนึ่งๆ ที่เกี่ยวข้องกับเหตุการณ์ของระบบ
Jetpack มี API การติดตามที่คุณสามารถใช้เพื่อติดป้ายกำกับให้กับบางส่วนของ โค้ด จากนั้นระบบจะรายงานข้อมูลนี้เป็นร่องรอยที่บันทึกไว้ในอุปกรณ์ การเปรียบเทียบมาโคร จะบันทึกการติดตามด้วยจุดการติดตามที่กำหนดเองโดยอัตโนมัติ
เมื่อใช้เครื่องมือบรรทัดคำสั่ง systrace เพื่อจับภาพการติดตาม ตัวเลือก -a
ต้องระบุ หากไม่มีตัวเลือกนี้ วิธีการของแอปจะไม่ปรากฏในระบบ
รายงานการติดตาม
Kotlin
class MyAdapter : RecyclerView.Adapter<MyViewHolder>() { override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder { trace("MyAdapter.onCreateViewHolder") { MyViewHolder.newInstance(parent) } } override fun onBindViewHolder(holder: MyViewHolder, position: Int) { trace("MyAdapter.onBindViewHolder") { trace("MyAdapter.queryDatabase") val rowItem = queryDatabase(position) dataset.add(rowItem) } holder.bind(dataset[position]) } } }
Java
public class MyAdapter extends RecyclerView.Adapter<MyViewHolder> { @NonNull @Override public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { return TraceKt.trace( "MyAdapter.onCreateViewHolder", () -> MyViewHolder.newInstance(parent) ); } @Override public void onBindViewHolder(@NonNull MyViewHolder holder, int position) { TraceKt.trace( "MyAdapter.onBindViewHolder", () -> { TraceKt.trace( "MyAdapter.queryDatabase", () -> { Item rowItem = queryDatabase(position); dataset.add(rowItem); } ); } ); } }
เราขอแนะนำให้ใช้ฟังก์ชันส่วนขยาย Kotlin แม้ในโค้ด Java เนื่องจาก สิ้นสุดการติดตามโดยอัตโนมัติเมื่อ lambda เสร็จสิ้น วิธีนี้จะช่วยลดความเสี่ยง การลืมที่จะสิ้นสุดการติดตาม
นอกจากนี้ คุณยังใช้ NDK API สําหรับเหตุการณ์การติดตามที่กําหนดเองได้ด้วย หากต้องการทราบข้อมูลเกี่ยวกับการใช้งาน API สำหรับโค้ดเนทีฟที่หัวข้อเหตุการณ์การติดตามที่กำหนดเองในโฆษณาเนทีฟ รหัส
แนะนำสำหรับคุณ
- หมายเหตุ: ข้อความลิงก์จะแสดงเมื่อ JavaScript ปิดอยู่
- เวลาเริ่มต้นของแอป
- การแสดงผลช้า