浅谈C# StackTrace 类的实例说明
来源:互联网 发布:windows phone app 编辑:程序博客网 时间:2024/05/17 07:26
转载自:http://www.cnblogs.com/qinpengming/archive/2011/05/30/2063192.html
using System.Diagnostics;
using System.Reflection; //反射
其中调用GetFrame得到栈空间,参数index 表示栈空间的级别,0表示当前栈空间,1表示上一级的栈空间,依次类推。
除了可以获取方法信息外,还可以调用StackFrame类的成员函数,在运行时得到代码的文件信息及行号和列号等
如下实例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
using
System;
using
System.Collections.Generic;
using
System.Linq;
using
System.Text;
using
System.Diagnostics;
using
System.Reflection;
namespace
ConsoleTest
{
class
Program
{
static
void
Main(
string
[] args)
{
MyInternalClass myClass =
new
MyInternalClass();
myClass.MyPublicMethod();
}
}
class
MyInternalClass
{
public
void
ThrowsException()
{
try
{
throw
new
Exception(
"错误信息"
);
}
catch
{
StackTrace st =
new
StackTrace(
true
);
string
stackIndent =
""
;
for
(
int
i = 0; i < st.FrameCount; i++)
{
StackFrame sf = st.GetFrame(i);
Console.WriteLine();
//得到错误的方法
Console.WriteLine(stackIndent +
" Method: {0}"
,
sf.GetMethod());
//得到错误的文件名
Console.WriteLine(stackIndent +
" File: {0}"
,
sf.GetFileName());
//得到文件错误的行号
Console.WriteLine(stackIndent +
" Line Number: {0}"
,
sf.GetFileLineNumber());
//得到错误的列
Console.WriteLine(
" Column Number: {0}"
, sf.GetFileColumnNumber());
stackIndent +=
" "
;
}
}
}
protected
void
MyProtectedMethod()
{
MyInternalClass mic =
new
MyInternalClass();
mic.ThrowsException();
}
public
void
MyPublicMethod()
{
MyProtectedMethod();
}
}
}
结果如图:
0 0
- 浅谈C# StackTrace 类的实例说明
- 一个StackTrace类
- StackTrace
- StackTrace简述以及StackTraceElement使用实例
- C#使用StackTrace、StackFrame、MethodBase获取当前属性时遇到的麻烦
- 捕捉Java的异常Stacktrace
- c# 方法调用链System.Diagnostics.StackTrace
- 浅谈Java类的实例化
- 挖一挖C#中那些我们不常用的东西之系列(3)——StackTrace,Trim
- Exception 的 StackTrace 信息的丢失
- 保存Exception的StackTrace到StringBuffer中
- JVM 看不到某些异常的stacktrace问题
- ndk-stacktrace-analyzer 工具的使用
- 浅谈C#类成员的访问属性
- hashcode的实例说明
- c#的反射浅谈
- c# 类的反射实例
- c#接口详解及实例说明
- MySQL数据库学习日志5.11
- MRTG安装教程
- 结构型模式之代理模式(Proxy)
- (亲测可用)html5调用手机摄像头
- Jetty 的工作原理以及与 Tomcat 的比较
- 浅谈C# StackTrace 类的实例说明
- 【Java】建立一个0-10M的字符串消息
- (转)Cookie与Session的区别-总结很好的文章
- windows10_注册表_图片编辑器
- 使用谷歌学术检索论文小技巧
- Linux下使用python脚本执行BCP导入导出操作
- JAVA学习第3天 Struts2
- VBA 判断sheet页面是否为空,不为空则清空数据
- js动态生成表格