浅析StackTrace

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

None.gif class  Program
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
static void Main(string[] args)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            Program a 
= new Program();
InBlock.gif            a.FuncA();
InBlock.gif            Console.ReadLine();
ExpandedSubBlockEnd.gif        }

InBlock.gif        
int FuncA()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            FuncB();
InBlock.gif            
return 0;
ExpandedSubBlockEnd.gif        }

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

ExpandedBlockEnd.gif    }

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

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

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

None.gif
if (sf.GetNativeOffset() != StackFrame.OFFSET_UNKNOWN)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif   Console.WriteLine(
" Native Offset: {0}"
InBlock.gif      sf.GetNativeOffset());
ExpandedBlockEnd.gif}

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

转载于:https://www.cnblogs.com/isabelincoln/archive/2006/11/02/547544.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C中的stacktrace是指在程序运行过程中,记录函数调用关系和执行位置的一种机制。当程序发生错误或异常情况时,可以通过stacktrace来定位问题发生的位置,帮助开发人员进行调试和错误修复。 在C语言中,stacktrace可以通过获取函数调用栈来实现。函数调用栈是一个存储函数调用关系和局部变量的数据结构,栈顶表示当前正在执行的函数。可以通过以下几种方法来获取C的stacktrace: 1. 使用调试工具:在开发环境中,可以使用调试工具(如GDB)来获取stacktrace。通过设置断点或捕捉异常,可以在程序执行过程中暂停并查看函数调用栈的信息。 2. 异常处理:在代码中可以使用异常处理机制来捕获异常,并将stacktrace作为异常信息输出。可以使用`backtrace`和`backtrace_symbols`等函数获取函数调用栈的信息,并将其打印出来。 3. 自定义实现:也可以自己编写代码来实现获取stacktrace的功能。使用函数指针的方式,将每个函数的调用关系保存在一个自定义的数据结构中,并在需要时打印出来。 无论使用哪种方法,获取stacktrace可以帮助开发人员更快地定位问题发生的位置,从而快速解决bug。在生产环境中,由于性能和安全等方面的考虑,通常需要做一些限制,避免泄露敏感信息。因此,在实际应用中需要根据具体需求来选择合适的方法来获取stacktrace
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值