我们在学习函数调用时,都知道每个函数都拥有自己的栈空间。一个函数被调用时,就创建一个新的栈空间。那么通过函数的嵌套调用最后就形成了一个函数调用堆栈。在c#中,使用StackTrace记录这个堆栈。你可以在程序运行过程中使用StackTrace得到当前堆栈的信息。

浅析StackTrace
    




浅析StackTraceclass Program
    
        static void Main(string[] args)
        
            Program a = new Program();
浅析StackTrace
    




浅析StackTrace            a.FuncA();
浅析StackTrace
    




浅析StackTrace            Console.ReadLine();
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace        
int FuncA()
        
            FuncB();
浅析StackTrace
    




浅析StackTrace            
return 0;
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace
浅析StackTrace
    




浅析StackTrace        
private void FuncB()
        
            MethodInfo method0 = (MethodInfo)(new StackTrace().GetFrame(0).GetMethod());
浅析StackTrace
    




浅析StackTrace            MethodInfo method1 
= (MethodInfo)(new StackTrace().GetFrame(1).GetMethod());
浅析StackTrace
    




浅析StackTrace            MethodInfo method2 
= (MethodInfo)(new StackTrace().GetFrame(2).GetMethod());
浅析StackTrace
    




浅析StackTrace            
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"Current Method is : {0}",method0.Name);
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"Parent Method is : {0}", method1.Name);
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"GrandParent Method is : {0}", method2.Name);
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace    }

程序的输出结果是:
Current Method is : FuncB
Parent Method is : FuncA
GrandParent Method is : Main

       其中调用GetFrame得到栈空间,参数index 表示栈空间的级别,0表示当前栈空间,1表示上一级的栈空间,依次类推。
       除了可以获取方法信息外,还可以调用StackFrame类的成员函数,在运行时得到代码的文件信息及行号和列号等。详情可以参考msdn上的一个example

// Display the stack frame properties.
浅析StackTrace
    




浅析StackTrace
StackFrame sf = st.GetFrame(i);
浅析StackTrace
    




浅析StackTraceConsole.WriteLine(
" File: {0}", sf.GetFileName());
浅析StackTrace
    




浅析StackTraceConsole.WriteLine(
" Line Number: {0}"
浅析StackTrace
    




浅析StackTrace   sf.GetFileLineNumber());
浅析StackTrace
    




浅析StackTrace
// Note that the column number defaults to zero
浅析StackTrace
    




浅析StackTrace
// when not initialized.
浅析StackTrace
    




浅析StackTrace
Console.WriteLine(" Column Number: {0}"
浅析StackTrace
    




浅析StackTrace   sf.GetFileColumnNumber());
浅析StackTrace
    




浅析StackTrace
if (sf.GetILOffset() != StackFrame.OFFSET_UNKNOWN)
   Console.WriteLine(" Intermediate Language Offset: {0}"
浅析StackTrace
    




浅析StackTrace      sf.GetILOffset());
浅析StackTrace
    




浅析StackTrace}

浅析StackTrace
    




浅析StackTrace
if (sf.GetNativeOffset() != StackFrame.OFFSET_UNKNOWN)
   Console.WriteLine(" Native Offset: {0}"
浅析StackTrace
    




浅析StackTrace      sf.GetNativeOffset());
浅析StackTrace
    




浅析StackTrace}

在dudu的文章Attribute在.NET编程中的应用(四)一文中,就是通过StackTrace得到了其上一级的函数信息,即AddCustomer的信息,来进一步创建SqlParameter 的。详情请参见其文章

       我们在学习函数调用时,都知道每个函数都拥有自己的栈空间。一个函数被调用时,就创建一个新的栈空间。那么通过函数的嵌套调用最后就形成了一个函数调用堆栈。在c#中,使用StackTrace记录这个堆栈。你可以在程序运行过程中使用StackTrace得到当前堆栈的信息。

浅析StackTrace
    




浅析StackTraceclass Program
    
        static void Main(string[] args)
        
            Program a = new Program();
浅析StackTrace
    




浅析StackTrace            a.FuncA();
浅析StackTrace
    




浅析StackTrace            Console.ReadLine();
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace        
int FuncA()
        
            FuncB();
浅析StackTrace
    




浅析StackTrace            
return 0;
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace
浅析StackTrace
    




浅析StackTrace        
private void FuncB()
        
            MethodInfo method0 = (MethodInfo)(new StackTrace().GetFrame(0).GetMethod());
浅析StackTrace
    




浅析StackTrace            MethodInfo method1 
= (MethodInfo)(new StackTrace().GetFrame(1).GetMethod());
浅析StackTrace
    




浅析StackTrace            MethodInfo method2 
= (MethodInfo)(new StackTrace().GetFrame(2).GetMethod());
浅析StackTrace
    




浅析StackTrace            
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"Current Method is : {0}",method0.Name);
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"Parent Method is : {0}", method1.Name);
浅析StackTrace
    




浅析StackTrace            Console.WriteLine(
"GrandParent Method is : {0}", method2.Name);
浅析StackTrace
    




浅析StackTrace        }

浅析StackTrace
    




浅析StackTrace    }

程序的输出结果是:
Current Method is : FuncB
Parent Method is : FuncA
GrandParent Method is : Main

       其中调用GetFrame得到栈空间,参数index 表示栈空间的级别,0表示当前栈空间,1表示上一级的栈空间,依次类推。
       除了可以获取方法信息外,还可以调用StackFrame类的成员函数,在运行时得到代码的文件信息及行号和列号等。详情可以参考msdn上的一个example

// Display the stack frame properties.
浅析StackTrace
    




浅析StackTrace
StackFrame sf = st.GetFrame(i);
浅析StackTrace
    




浅析StackTraceConsole.WriteLine(
" File: {0}", sf.GetFileName());
浅析StackTrace
    




浅析StackTraceConsole.WriteLine(
" Line Number: {0}"
浅析StackTrace
    




浅析StackTrace   sf.GetFileLineNumber());
浅析StackTrace
    




浅析StackTrace
// Note that the column number defaults to zero
浅析StackTrace
    




浅析StackTrace
// when not initialized.
浅析StackTrace
    




浅析StackTrace
Console.WriteLine(" Column Number: {0}"
浅析StackTrace
    




浅析StackTrace   sf.GetFileColumnNumber());
浅析StackTrace
    




浅析StackTrace
if (sf.GetILOffset() != StackFrame.OFFSET_UNKNOWN)
   Console.WriteLine(" Intermediate Language Offset: {0}"
浅析StackTrace
    




浅析StackTrace      sf.GetILOffset());
浅析StackTrace
    




浅析StackTrace}

浅析StackTrace
    




浅析StackTrace
if (sf.GetNativeOffset() != StackFrame.OFFSET_UNKNOWN)
   Console.WriteLine(" Native Offset: {0}"
浅析StackTrace
    




浅析StackTrace      sf.GetNativeOffset());
浅析StackTrace
    




浅析StackTrace}

在dudu的文章Attribute在.NET编程中的应用(四)一文中,就是通过StackTrace得到了其上一级的函数信息,即AddCustomer的信息,来进一步创建SqlParameter 的。详情请参见其文章

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-08-18
  • 2022-12-23
  • 2022-12-23
  • 2021-10-31
  • 2022-12-23
猜你喜欢
  • 2022-02-18
  • 2021-08-17
  • 2021-12-10
  • 2021-05-03
  • 2022-12-23
  • 2021-07-11
相关资源
相似解决方案