c# 方法调用链System.Diagnostics.StackTrace[通俗易懂]

2022-09-12 14:09:50 浏览数 (1)

大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说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());
}

输出结果:

0 人点赞