כברירת מחדל, המיקרו-בנצ'מרקים מספקים מידע על התזמון וההקצאות של הקוד שהופעל. אם רוצים לבדוק למה הקוד שנמדד פועל לאט, אפשר לבדוק את מעקב השיטה – שמתבצע כברירת מחדל בגרסאות נתמכות של מערכת ההפעלה – או לבחור הגדרות אחרות של פרופילים.
כדי לבחור את ההגדרה של כלי הפרופיל, מוסיפים את ארגומנט ההרצה של האינסטרומנטציה
androidx.benchmark.profiling.mode עם אחד מהארגומנטים
MethodTracing (ברירת מחדל),
StackSampling או None, כמו שמוצג בקטע הקוד הבא.
מידע נוסף על האפשרויות זמין במאמר תיעוד של שיטות Java/Kotlin.
MethodTracing שווה ערך למעקב, ו-StackSampling שווה ערך לדגימה, כפי שמוגדר במסמך הזה.
Groovy
android { defaultConfig { // must be one of: 'None', 'StackSampling', or 'MethodTracing' testInstrumentationRunnerArguments["androidx.benchmark.profiling.mode"]= 'StackSampling' } }
Kotlin
android { defaultConfig { // must be one of: 'None', 'StackSampling', or 'MethodTracing' testInstrumentationRunnerArguments["androidx.benchmark.profiling.mode"] = "StackSampling" } }
כשמבצעים תיעוד של השוואה (benchmark), קובץ הפלט .trace מועתק למארח בספרייה לצד תוצאות ה-JSON. כדי לבדוק את תוצאות הפרופיל ב-Android Studio, לוחצים על הקישור Method Trace או Stack Sampling Trace בתוצאות המיקרו-בנצ'מרק.
MethodTracing
מעקב אחר שיטות שימושי כשמנסים לבצע אופטימיזציה של הקוד, כי הוא יכול לעזור לזהות את השיטות שלוקח להן יותר זמן לפעול מאשר לאחרות. לאחר מכן תוכלו להתמקד באופטימיזציה של השיטות שהכי משפיעות על הביצועים.
הפרופיל נוצר ברצף אחרי מדידת הקוד, כך שתוצאות הבדיקה כוללות גם תזמון מדויק וגם פרופיל.
התכונה 'מעקב אחר שיטות' מופעלת כברירת מחדל.
StackSampling
דגימת מעקב יכולה גם לעזור לזהות שיטות יקרות בלי להשפיע על הביצועים כמו מעקב שיטות. עם זאת, אם האפליקציה נכנסת לשיטה אחרי שדוח הקריסות תועד והשיטה יוצאת לפני התיעוד הבא, קריאת השיטה לא מתועדת. כדי לעקוב בצורה נכונה אחרי שיטות עם מחזורי חיים קצרים, כדאי להשתמש במעקב אחר שיטות במקום במעקב אחר דגימות.
בשיטה של קבוצת דגימות, המדד של ההשוואה לשוק דוגם את מחסנית הקריאות אחרי שתקופת ההכנה מסתיימת. אפשר לשלוט בהתנהגות הדגימה, כמו תדירות הדגימה ומשך הדגימה, באמצעות ארגומנטים של מכשור.
ב-Android 10 (API 29) ומעלה, דגימת מחסנית משתמשת ב-Simpleperf כדי לדגום את מחסניות הקריאות של האפליקציה, כולל קוד C++. ב-Android 9 (API 28) ובגרסאות קודמות, נעשה שימוש ב-Debug.startMethodTracingSampling כדי לתעד דגימות של מחסנית.
כדי להגדיר את מצב הפרופיל הזה, מוסיפים עוד ארגומנטים של מכשור:
androidx.benchmark.profiling.sampleFrequency- מספר דגימות המקבץ שצריך לצלם בכל שנייה.
- סוג הארגומנט: מספר שלם
- ברירת המחדל היא 1,000 דגימות לשנייה.
androidx.benchmark.profiling.sampleDurationSeconds- משך ההשוואה לשוק.
- סוג הארגומנט: מספר שלם
- ברירת המחדל היא 5 שניות.
androidx.benchmark.profiling.skipWhenDurationRisksAnr- מדלג על מעקב אחר שיטות כשיש סיכוי גבוה שזה יגרום ל-ANR. מומלץ להשאיר את האפשרות הזו מופעלת להרצות CI, כי שגיאות ANR עלולות לגרום לבעיות במהלך הרצות CI ארוכות.
- סוג הארגומנט: Boolean (בוליאני)
- ברירת המחדל היא
true
ללא
הארגומנט הזה לא מתעד קובץ פרופיל. עדיין נמדדים נתונים לגבי לוחות זמנים והקצאות.
מומלץ בשבילך
- הערה: טקסט הקישור מוצג כש-JavaScript מושבת
- ארגומנטים של אינסטרומנטציה ל-Microbenchmark
- הרצת נקודות השוואה באינטגרציה רציפה