Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Log Jejak Tindanan dalam .NET Tanpa Pengecualian?
Melog Jejak Tindanan dalam .NET Tanpa Kehadiran Pengecualian
Apabila menyahpepijat kod, mencetak jejak tindanan semasa boleh menjadi tidak ternilai untuk memahami aliran program dan mengenal pasti isu. Walau bagaimanapun, dalam situasi di mana tiada pengecualian telah berlaku, pendekatan standard menggunakan blok cuba-tangkap atau sifat Exception.StackTrace tidak akan berfungsi.
Penyelesaian
Untuk mencetak surih tindanan semasa tanpa pengecualian, gunakan System.Diagnostics.StackTrace kelas:
System.Diagnostics.StackTrace t = new System.Diagnostics.StackTrace();
t akan mengandungi maklumat tentang kaedah yang sedang dilaksanakan, pemanggilnya dan seterusnya, sehingga titik masuk program.
Contoh
Pertimbangkan kod berikut:
public void executeMethod() { logStackTrace(); method(); }
Jika kita memanggil executeMethod() dan kemudian cetak surih tindanan, kita akan melihat sesuatu seperti:
at executeMethod() in C:\Path\To\MyCode.cs:line 10 at method() in C:\Path\To\MyCode.cs:line 15 at Program.Main() in C:\Path\To\MyMain.cs:line 20
Surian ini menunjukkan kepada kita tindanan panggilan, walaupun tiada pengecualian telah berlaku.
Sumber Tambahan
Untuk alat penyahpepijatan lanjut, terokai ruang nama System.Diagnostics. Rangka kerja pengelogan seperti NLog, log4net dan Pustaka Perusahaan menyediakan penyelesaian pengelogan yang komprehensif, termasuk keupayaan untuk menangkap jejak tindanan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Log Jejak Tindanan dalam .NET Tanpa Pengecualian?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!