মেট্রিক্স হল আপনার বেঞ্চমার্ক থেকে বের করা তথ্যের প্রধান প্রকার। এগুলিকে একটি List
হিসাবে measureRepeated
ফাংশনে পাঠানো হয়, যা আপনাকে একবারে একাধিক পরিমাপ করা মেট্রিক্স নির্দিষ্ট করতে দেয়। বেঞ্চমার্ক চালানোর জন্য কমপক্ষে এক ধরনের মেট্রিক প্রয়োজন।
নিম্নলিখিত কোড স্নিপেট ফ্রেম টাইমিং এবং কাস্টম ট্রেস বিভাগ মেট্রিক্স ক্যাপচার করে:
কোটলিন
benchmarkRule.measureRepeated( packageName = TARGET_PACKAGE, metrics = listOf( FrameTimingMetric(), TraceSectionMetric("RV CreateView"), TraceSectionMetric("RV OnBindView"), ), iterations = 5, // ... )
জাভা
benchmarkRule.measureRepeated( TARGET_PACKAGE, // packageName Arrays.asList( // metrics new StartupTimingMetric(), new TraceSectionMetric("RV CreateView"), new TraceSectionMetric("RV OnBindView"), ), 5, // Iterations // ... );
এই উদাহরণে, RV CreateView
এবং RV OnBindView
হল ট্রেসযোগ্য ব্লকের ID যা RecyclerView
এ সংজ্ঞায়িত করা হয়েছে। createViewHolder()
পদ্ধতির সোর্স কোড হল আপনি কীভাবে আপনার নিজের কোডের মধ্যে ট্রেসযোগ্য ব্লকগুলিকে সংজ্ঞায়িত করতে পারেন তার একটি উদাহরণ।
StartupTimingMetric
, TraceSectionMetric
, FrameTimingMetric
, এবং PowerMetric
, এই নথিতে পরে বিস্তারিতভাবে কভার করা হয়েছে৷
বেঞ্চমার্ক ফলাফলগুলি অ্যান্ড্রয়েড স্টুডিওতে আউটপুট হয়, যেমন চিত্র 1-এ দেখানো হয়েছে। যদি একাধিক মেট্রিক্স সংজ্ঞায়িত করা হয়, তবে তাদের সবকটি আউটপুটে একত্রিত করা হয়।

TraceSectionMetric
এবং FrameTimingMetric
এর ফলাফল।স্টার্টআপ টাইমিংমেট্রিক
StartupTimingMetric
নিম্নলিখিত মানগুলির সাথে অ্যাপ স্টার্টআপ টাইমিং মেট্রিক্স ক্যাপচার করে:
-
timeToInitialDisplayMs
: যখন সিস্টেমটি লঞ্চের উদ্দেশ্য গ্রহণ করে তখন থেকে এটি গন্তব্যActivity
প্রথম ফ্রেম রেন্ডার করার সময় পর্যন্ত। -
timeToFullDisplayMs
: সিস্টেমটি লঞ্চের অভিপ্রায় প্রাপ্ত হওয়ার সময় থেকেreportFullyDrawn()
পদ্ধতি ব্যবহার করে অ্যাপটি সম্পূর্ণভাবে অঙ্কিত হওয়ার সময় পর্যন্ত। পরিমাপটিreportFullyDrawn()
কলের পরে প্রথম ফ্রেমের রেন্ডারিং-এর সমাপ্তিতে থেমে যায়। এই পরিমাপটি Android 10 (API স্তর 29) এবং তার আগে উপলব্ধ নাও হতে পারে।
StartupTimingMetric
স্টার্টআপ পুনরাবৃত্তি থেকে ন্যূনতম, মধ্যমা এবং সর্বোচ্চ মান বের করে। স্টার্টআপ উন্নতির মূল্যায়ন করার জন্য আপনাকে মধ্যম মানের উপর ফোকাস করা উচিত, যেহেতু তারা সাধারণ স্টার্টআপ সময়ের সেরা অনুমান প্রদান করে। অ্যাপ স্টার্টআপের সময় কী অবদান রাখে সে সম্পর্কে আরও তথ্যের জন্য, অ্যাপ শুরুর সময় দেখুন।

StartupTimingMetric
ফলাফল।ফ্রেমটাইমিংমেট্রিক
FrameTimingMetric
একটি বেঞ্চমার্ক দ্বারা উত্পাদিত ফ্রেম থেকে সময় সংক্রান্ত তথ্য ক্যাপচার করে, যেমন একটি স্ক্রলিং বা অ্যানিমেশন, এবং নিম্নলিখিত মানগুলি আউটপুট করে:
-
frameOverrunMs
: যে পরিমাণ সময় একটি প্রদত্ত ফ্রেম তার সময়সীমা মিস করে। ইতিবাচক সংখ্যাগুলি একটি ড্রপ ফ্রেম এবং দৃশ্যমান জ্যাঙ্ক বা তোতলান নির্দেশ করে৷ ঋণাত্মক সংখ্যা নির্দেশ করে যে একটি ফ্রেম সময়সীমার চেয়ে কত দ্রুত। দ্রষ্টব্য: এটি শুধুমাত্র Android 12 (API স্তর 31) এবং উচ্চতর সংস্করণে উপলব্ধ। -
frameDurationCpuMs
: UI থ্রেড এবংRenderThread
উভয়ের CPU-তে ফ্রেমটি তৈরি হতে যে পরিমাণ সময় লাগে।
এই পরিমাপগুলি 50 তম, 90 তম, 95 তম এবং 99 তম শতাংশের বিতরণে সংগ্রহ করা হয়।
ধীরগতির ফ্রেমগুলি কীভাবে সনাক্ত এবং উন্নত করতে হয় সে সম্পর্কে আরও তথ্যের জন্য, স্লো রেন্ডারিং দেখুন।

FrameTimingMetric
ফলাফল।ট্রেস সেকশনমেট্রিক
TraceSectionMetric
প্রদত্ত sectionName
সাথে মেলে একটি ট্রেস সেকশন কতবার ঘটে এবং কতটা সময় নেয় তা ক্যাপচার করে। সময়ের জন্য, এটি মিলিসেকেন্ডে সর্বনিম্ন, মাঝারি এবং সর্বোচ্চ বার আউটপুট করে। ট্রেস বিভাগটি হয় ফাংশন কল trace(sectionName)
অথবা Trace.beginSection(sectionName)
এবং Trace.endSection()
বা তাদের async ভেরিয়েন্টের মধ্যে কোড দ্বারা সংজ্ঞায়িত করা হয়। এটি সর্বদা একটি পরিমাপের সময় ক্যাপচার করা একটি ট্রেস বিভাগের প্রথম উদাহরণ নির্বাচন করে। এটি ডিফল্টরূপে আপনার প্যাকেজ থেকে শুধুমাত্র ট্রেস বিভাগ আউটপুট; আপনার প্যাকেজের বাইরে প্রসেস অন্তর্ভুক্ত করতে, targetPackageOnly = false
সেট করুন।
ট্রেসিং সম্পর্কে আরও তথ্যের জন্য, সিস্টেম ট্রেসিংয়ের ওভারভিউ দেখুন এবং কাস্টম ইভেন্টগুলি সংজ্ঞায়িত করুন ।

TraceSectionMetric
ফলাফল।পাওয়ারমেট্রিক
PowerMetric
প্রদত্ত পাওয়ার বিভাগের জন্য আপনার পরীক্ষার সময়কাল ধরে শক্তি বা শক্তির পরিবর্তন ক্যাপচার করে। প্রতিটি নির্বাচিত বিভাগকে তার পরিমাপযোগ্য উপ-উপাদানে বিভক্ত করা হয় এবং অনির্বাচিত বিভাগগুলি "অনির্বাচিত" মেট্রিকে যোগ করা হয়।
এই মেট্রিকগুলি সিস্টেম-ব্যাপী খরচ পরিমাপ করে, প্রতি-অ্যাপ ভিত্তিতে খরচ নয় এবং Pixel 6, Pixel 6 Pro এবং পরবর্তী ডিভাইসগুলিতে সীমাবদ্ধ:
-
power<category>Uw
: এই বিভাগে আপনার পরীক্ষার সময়কাল ধরে ব্যবহৃত পাওয়ারের পরিমাণ। -
energy<category>Uws
: এই বিভাগে আপনার পরীক্ষার সময়কালের জন্য প্রতি ইউনিটে স্থানান্তরিত শক্তির পরিমাণ।
বিভাগগুলির মধ্যে নিম্নলিখিতগুলি অন্তর্ভুক্ত রয়েছে:
-
CPU
-
DISPLAY
-
GPU
-
GPS
-
MEMORY
-
MACHINE_LEARNING
-
NETWORK
-
UNCATEGORIZED
CPU
এর মত কিছু বিভাগের সাথে, আপনার নিজের অ্যাপ দ্বারা করা কাজ থেকে অন্যান্য প্রক্রিয়া দ্বারা করা কাজকে আলাদা করা কঠিন হতে পারে। হস্তক্ষেপ কমাতে, অপ্রয়োজনীয় অ্যাপ এবং অ্যাকাউন্টগুলি সরান বা সীমাবদ্ধ করুন।

PowerMetric
ফলাফল।আপনার জন্য প্রস্তাবিত
- দ্রষ্টব্য: জাভাস্ক্রিপ্ট বন্ধ থাকলে লিঙ্ক টেক্সট প্রদর্শিত হয়
- বেসলাইন প্রোফাইল তৈরি করুন {:#creating-profile-rules}
- একটি ম্যাক্রোবেঞ্চমার্ক লেখা
- অ্যাপ স্টার্টআপ বিশ্লেষণ এবং অপ্টিমাইজেশান {:#app-startup-analysis-optimization}