Menentukan Masa Keluar Fungsi dengan __gnu_mcount_nc
Dalam percubaan untuk melakukan pemprofilan prestasi pada platform terbenam, telah diambil perhatian bahawa GCC - pg flag memasukkan thunks kepada __gnu_mcount_nc pada entri ke setiap fungsi. Walaupun tiada pelaksanaan __gnu_mcount_nc tersedia, pelaksanaan tersuai yang merekodkan bingkai tindanan dan kiraan kitaran semasa telah terbukti berguna dalam mengumpul graf pemanggil/pemanggil dan mengenal pasti fungsi yang sering dipanggil.
Walau bagaimanapun, menangkap maklumat tentang masa yang dihabiskan dalam badan fungsi kekal sebagai cabaran semata-mata berdasarkan pintu masuk. Pendekatan sedia ada, seperti mengekalkan timbunan panggilan bayangan dan memanipulasi alamat pemulangan, memperkenalkan had dan overhed.
Untuk menangani persoalan pelaksanaan __gnu_mcount_nc alternatif yang membolehkan menangkap masa keluar fungsi, mari kita mendalami pendekatan sebenar yang digunakan oleh gprof.
Bagaimana gprof Mengukur Masa Fungsi
Bertentangan dengan andaian awal, gprof tidak menggunakan __gnu_mcount_nc untuk pemasaan fungsi masuk atau keluar. Sebaliknya, ia bergantung pada masa kendiri yang dikumpulkan dengan mengira sampel PC dalam setiap rutin. Sampel ini kemudiannya digunakan, bersama-sama dengan kiraan panggilan fungsi ke fungsi, untuk menganggarkan bahagian masa kendiri yang harus dikaitkan dengan pemanggil.
Pengiraan Panggilan lwn. Pensampelan Tindanan
Pendekatan lain ialah pensampelan tindanan, yang melibatkan penangkapan sampel tindanan pada selang masa yang tetap. Walaupun lebih mahal daripada pensampelan PC, ia memberikan ukuran yang lebih tepat kerana ia tidak membezakan antara panggilan pendek dan panjang, dan ia juga tidak terjejas oleh I/O atau rutin perpustakaan yang tidak mempunyai instrument.
Mengenal pasti Operasi yang Mahal
Kunci untuk mencari kesesakan prestasi terletak pada menganalisis sampel tindanan mentah dan mengaitkannya dengan kod sumber. Berbanding memfokuskan pada graf panggilan atau titik panas, memeriksa sampel tindanan individu boleh mendedahkan sebab khusus mengapa operasi tertentu mengambil masa yang ketara dan mencadangkan pengoptimuman yang mungkin.
Melangkaui Visualisasi Mewah
Walaupun visualisasi seperti graf nyalaan dan peta pokok boleh menarik secara visual, ia sering gagal untuk menyerlahkan isu prestasi yang berpunca daripada kod dipanggil berkali-kali dari lokasi yang berbeza. Mengagregat dan mengisih data mengikut fungsi, dan bukannya berdasarkan masa semata-mata, memberikan pandangan yang lebih komprehensif tentang pelaksanaan kod.
Kesimpulan
Walaupun __gnu_mcount_nc boleh memberikan maklumat berharga tentang titik masuk fungsi, kaedah alternatif seperti pensampelan tindanan harus dipertimbangkan untuk menangkap masa keluar fungsi. Dengan memfokuskan pada menganalisis sampel tindanan sebenar dan mengelakkan gangguan daripada visualisasi yang menarik perhatian, pembangun boleh mengenal pasti kesesakan prestasi dengan berkesan dan melaksanakan pengoptimuman.
Atas ialah kandungan terperinci Bagaimanakah Kami Boleh Mengukur Masa Keluar Fungsi dengan Tepat dalam Pemprofilan Prestasi Melebihi Menggunakan `__gnu_mcount_nc`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!