Melog Jejak Tindanan dalam .NET Tanpa Pengecualian
Apabila menyahpepijat aplikasi, ia boleh berguna untuk menangkap jejak tindanan semasa untuk mengenal pasti sumber sebarang isu. Walau bagaimanapun, dalam senario di mana tiada pengecualian dilemparkan, pengelogan surih tindanan boleh menjadi satu cabaran.
System.Diagnostics.StackTrace
Syukurlah, .NET System.Diagnostics ruang nama menyediakan penyelesaian untuk mencetak surih tindanan semasa. Kelas System.Diagnostics.StackTrace boleh digunakan untuk menangkap surih tindanan pada titik semasa dalam kod, walaupun apabila tiada pengecualian hadir.
Untuk menggunakan kelas ini, cuma buat contoh StackTrace dan panggil kaedah GetFramenya untuk dapatkan semula bingkai tindanan yang dikehendaki. Coretan kod berikut menunjukkan cara untuk log surih tindanan semasa ke konsol:
using System.Diagnostics; public class StackTraceDemo { public void ExecuteMethod() { StackTrace t = new StackTrace(); foreach (StackFrame frame in t.GetFrames()) { Console.WriteLine(frame.GetMethod().Name); } } }
Dalam contoh ini, kaedah GetFrame mengembalikan tatasusunan StackFrame objek mewakili timbunan benang semasa. Setiap StackFrame mengandungi maklumat tentang kaedah yang sedang dilaksanakan pada tahap tindanan yang sepadan, seperti namanya, nombor baris dan laluan fail.
Penyelesaian Pengelogan
Sebagai alternatif, anda boleh menggunakan penyelesaian pengelogan seperti NLog, log4net atau corak dan amalan Microsoft Perpustakaan Perusahaan untuk mencapai fungsi yang serupa. Perpustakaan ini menyediakan ciri tambahan seperti tahap pengelogan yang boleh disesuaikan, sokongan untuk sasaran pengelogan yang berbeza (cth., fail, pangkalan data) dan pengelogan berstruktur.
Kesimpulan
Dengan menggunakan System.Diagnostics.StackTrace penyelesaian kelas atau pembalakan, anda boleh log dengan mudah jejak tindanan semasa walaupun tiada pengecualian dilemparkan. Ini boleh menjadi tidak ternilai untuk tujuan penyahpepijatan dan mendapatkan cerapan tentang aliran pelaksanaan aplikasi.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Log Jejak Tindanan dalam Aplikasi .NET Tanpa Pengecualian?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!