要实现获取代码所在的位置信息的功能, 类System.Diagnostics.StackFrame是关键,源码如下:
执行结果如下:
C:\Users\Administrator\Desktop\ConsoleApplication1\ConsoleApplication1\Program.cs
24
13
ConsoleApplication1.exe
ConsoleApplication1.Program
Void SecondLevel()
分析如下:
构造函数StackFrame(int skipFrames, bool fNeedFileInfo)中,skipFrames为堆栈上帧跳过当前帧的帧数,fNeedFileInfo表示是否想获取堆栈帧所在文件名、行号、列号(Visual Studio 2010中,定位到构造函数StackFrame(1, true)调用处,按F12,即可看到此信息)。
那么什么是堆栈帧?“堆栈帧是在堆栈中为当前正在运行的函数分配的区域(或空间)。传入的参数、返回地址(当这个函数结束后必须跳转到该返回地址。译注:即主调函数的断点处)以及函数所用的内部存储单元(即函数存储在堆栈上的局部变量)都在堆栈帧中。”(http://book.51cto.com/art/200804/70915.htm)举个例子,A()调用B(),B()调用C(),那么,B()所处的堆栈帧刚好在C()所处堆栈帧的上一个,也就是说B()相对C()的帧跳数为1,A()的相对C()的帧跳数就为2。
好了,明白了这个,再来看将FirstLevel()中“StackFrame stackFrame = new StackFrame(1, true);”改为“StackFrame stackFrame = new StackFrame(2, true);”后的结果:
C:\Users\Administrator\Desktop\ConsoleApplication1\ConsoleApplication1\Program.cs
29
13
ConsoleApplication1.exe
ConsoleApplication1.Program
Void Main(System.String[])