大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说c# 方法调用链System.Diagnostics.StackTrace[通俗易懂],希望能够帮助大家进步!!!
一般用下面的方法处理:
代码语言:javascript复制/// <summary>
/// 获取调用链上的方法
/// </summary>
/// <param name="depth">回朔深度</param>
public static MethodBase GetCurrentMethod(int depth) {
try {
System.Diagnostics.StackTrace st = new System.Diagnostics.StackTrace();
return st.GetFrame(depth).GetMethod();
} catch {
return null;
}
}
只听到从架构师办公室传来架构君的声音:
百年草草都寒夜,自琢春词剪烛看。有谁来对上联或下联?
具体的调用回溯怎么理解请看下面的小demo:
代码语言:javascript复制此代码由Java架构师必看网-架构君整理
static void Main(string[] args) {
method1();
Console.ReadKey();
}
static void method1() {
method2();
Console.ReadLine();
}
static void method2() {
System.Diagnostics.StackTrace st = new System.Diagnostics.StackTrace(true);
Console.WriteLine(st.GetFrame(2).GetMethod().Name.ToString());
Console.WriteLine(st.GetFrame(1).GetMethod().Name.ToString());
Console.WriteLine(st.GetFrame(0).GetMethod().Name.ToString());
}
输出结果: