浅析StackTrace

我们在学习函数调用时, 都知道每个函数都拥有自己的栈空间。一个函数被调用时,就创建一个新的栈空间。那么通过函数的嵌套调用最后就形成了一个函数调用堆 栈。在c#中,使用StackTrace记录这个堆栈。你可以在程序运行过程中使用StackTrace得到当前堆栈的信息。
class Program
    
{
        
static void Main( string [] args)
        
{
             Program a
= new Program();
             a.FuncA();
             Console.ReadLine();
         }

        
int FuncA()
        
{
             FuncB();
            
return 0 ;
         }


        
private void FuncB()
        
{
             MethodInfo method0
= (MethodInfo)( new StackTrace().GetFrame( 0 ).GetMethod());
             MethodInfo method1
= (MethodInfo)( new StackTrace().GetFrame( 1 ).GetMethod());
             MethodInfo method2
= (MethodInfo)( new StackTrace().GetFrame( 2 ).GetMethod());
            
             Console.WriteLine(
" Current Method is : {0} " ,method0.Name);
             Console.WriteLine(
" Parent Method is : {0} " , method1.Name);
             Console.WriteLine(
" GrandParent Method is : {0} " , method2.Name);
         }

     }

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

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

msdn example
// Display the stack frame properties.
StackFrame sf = st.GetFrame(i);
Console.WriteLine(
" File: {0}", sf.GetFileName());
Console.WriteLine(
" Line Number: {0}",
    sf.GetFileLineNumber());
// Note that the column number defaults to zero
// when not initialized.
Console.WriteLine(" Column Number: {0}",
    sf.GetFileColumnNumber());
if (sf.GetILOffset() != StackFrame.OFFSET_UNKNOWN)
{
    Console.WriteLine(
" Intermediate Language Offset: {0}",
       sf.GetILOffset());
}

if (sf.GetNativeOffset() != StackFrame.OFFSET_UNKNOWN)
{
    Console.WriteLine(
" Native Offset: {0}",
       sf.GetNativeOffset());
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值