浅析StackTrace
来源:互联网 发布:淘宝客服发展前景 编辑:程序博客网 时间:2024/06/05 04:01
浅析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);
}
}
{
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
// 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());
}
在dudu的文章Attribute在.NET编程中的应用(四)一文中,就是通过StackTrace得到了其上一级的函数信息,即AddCustomer的信息,来进一步创建SqlParameter 的。详情请参见其文章。
- 浅析StackTrace
- 浅析StackTrace
- 浅析C++ StackTrace 堆栈轨迹
- StackTrace
- 关于stacktrace
- stacktrace-----调试
- 一个StackTrace类
- Get StackTrace as String
- android-ndk-stacktrace-analyzer
- c++ print stacktrace
- 使用Stacktrace处理异常
- stacktrace调试相关
- Diagnostics.StackTrace指定堆栈帧
- StackTrace和StackFrame使用笔记
- 捕捉Java的异常Stacktrace
- Exception 的 StackTrace 信息的丢失
- 保存Exception的StackTrace到StringBuffer中
- JVM 看不到某些异常的stacktrace问题
- TCP/IP详解基于4.4BSD-Lite源码
- ruby +watir +cucumber 安装
- Android OpenGL ES 2.0画立方体JNI实现
- 正在设定sun-java6-jre解决方法
- linux: C++ create JVM to invoke Java method
- 浅析StackTrace
- CentOS 5.X 安装 GForge ,安装 postgresql (gforge安装)
- 程序设计师真情忏悔录
- sina sdk 返回来的结果(给自己看的!)
- C#调用Win32 的API函数--User32.dll
- UVa216
- POJ 2516(最小费用最大流)
- XE2 日期字符串转日期的函数
- 《HP大中华区总裁孙振耀退休感言》