类库探源——System.Exception
一、MSDN描述
Exception 类: 表示在应用程序执行期间发生的错误
命名空间 : System
程序集: mscorlib.dll
继承关系:

常用属性(含字段)和方法:
1. 属性
Message 描述当前异常的消息
StackTrace 获取调用堆栈上直接帧的字符串表示形式(说白了就是导致异常的函数调用栈信息)
Source 获取导致异常的应用程序或对象名称
TargetSite 获取引发异常的方法
其中 StackTrace 属性最有用
2.方法
ToString 返回当前异常的字符串表示形式(重写Object.ToString())
备注:
1. Exception 的常见用法 try-catch 块(用try包裹待执行的代码,用catch来捕捉待执行代码出现的异常)
2. try-catch-finally 块,即使异常发生 finally 也会进,finally中放清理资源的代码
3. using语句会自动生成try-finally 的IL
二、一些建议
1.不要返回错误码(用返回错误码表示异常是Win32时期的特色,在.NET时代这是不允许的)
2.要通过抛出异常的方式来报告失败
3.不要轻易吃掉异常,如果是异常就应该抛出
4.不要把异常作为业务逻辑分支
try
{
逻辑A
}
catch
{
逻辑B
} 后续逻辑
5. 不要让公有成员根据某个选项来决定是否抛出异常
public Type GetType(string name,bool throwOnError); // 不好的设计
像上面的API设计通常反映出框架设计者的无力做出决定。一个方法要么成功,要么失败,而失败了就应该抛出异常。框架设计者未能做出决定,这迫使API调用者来决定,但由于调用者并不了解API的实现细节,因此他们更难做出正确的决定
6.异常的抛出应该选择最具有描述性的一个(如系统没有该异常,考虑自定义一个异常)
如try 语句块的功能是解析某参数,那么catch 块就应该优先用 ArgumentException (参数异常),最后再用 Exception 来捕获其他异常
try{}
catch(ArgumentException ex){}
catch(Exception ex){}
7. 用 Try-Parse 模式
如 DateTime.TryParse 这是综合了性能和异常处理的好东西,比直接 DateTime.Parse 好
三、使用log4net记录异常信息
官网:http://logging.apache.org/log4net/
1. 配置 log4net.config
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<root>
<level value="ALL" />
<appender-ref ref="Text" />
</root>
<appender name="Text" type="log4net.Appender.RollingFileAppender">
<param name="File" value="D:\log4netDemo\log4netDemoApp.log" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="1000" />
<param name="MaximumFileSize" value="1024KB" />
<param name="RollingStyle" value="Size" />
<param name="StaticLogFileName" value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
</layout>
</appender>
</log4net>
修改上面的 <param name="File" value="D:\log4netDemo\log4netDemoApp.log" /> 改为你想要的日志存放路径
注意这个 log4net.config 应该编译输入到程序目录(如:bin\Debug)
2. 在主程序启动类中写如下代码
private const string c_logConfig = "log4net.config";
private log4net.ILog _log = log4net.LogManager.GetLogger(typeof(Program)); static void Main(string[] args)
{
using (Stream stream = File.OpenRead(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, c_logConfig)))
{
XmlConfigurator.Configure(stream);
}
。。。 }
3. 使用
_log.Info("Start");
_log.Error("捕捉到异常{0}", ex);
更多log4net方法,查看API文档
四、全局异常捕获
AppDomain.CurrentDomain.UnhandledException
static void Mian()
{
AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);
}
static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
{
Exception error = (Exception)e.ExceptionObject;
_log.Error("MyHandler caught : " + error.Message);
}
WinForm、WPF、ASP.NET 均有全局异常捕获
五、多线程中的异常捕获
错误的捕获方式:
static void ThreadException1()
{
var t = new Thread(() => { throw new Exception("线程抛出异常"); });
try
{
t.Start();
}
catch (Exception ex)
{
// 这样捕获不到线程异常
_log.Error("捕获到线程异常 {0}", ex);
}
}
正确的捕获方式:
static void ThreadException2()
{
var t = new Thread(() =>
{
try
{
throw new Exception("线程抛出异常");
}
catch (Exception ex)
{
_log.Error("捕获到线程异常 {0}", ex);
}
});
t.Start();
}
六、系统事件查看器
这是一个很有用的功能,估计还有不少同学不知道
右键计算机(我的电脑) ==> 管理 ==> 计算机管理


本文代码下载
类库探源——System.Exception的更多相关文章
- 类库探源——System.Delegate
一.MSDN 描述 Delegate 类:表示委托,委托是一种数据结构,它引用静态方法或引用类实例及该类的实例方法.(是不是感觉很像C语言中的函数指针 :) ) 命名空间: System 程序集: ...
- 类库探源——System.Configuration 配置信息处理
按照MSDN描述 System.Configuration 命名空间 包含处理配置信息的类型 本篇文章主要两方面的内容 1. 如何使用ConfigurationManager 读取AppSetting ...
- 类库探源——System.Drawing.Bitmap
一.System.Drawing.Bitmap Bitmap 类: 封装GDI+ 位图,此位图由图形图像及其属性的像素数据组成.Bitmap 是用于处理由像素定义的图像的对象 命名空间: System ...
- 类库探源——System.Drawing
一.System.Drawing 命名空间简述 System.Drawing 命名空间提供访问 GDI+ 的基本功能,更高级的功能在 System.Drawing.Drawing2D,System.D ...
- 类库探源——System.Math 和 Random
一.System.Math Math类:为三角函数.对数函数和其他通用数学函数提供常数和静态方法 命名空间: System 程序集 : mscorlib.dll 继承关系: 常用属性: Math. ...
- 类库探源——System.ValueType
一.MSDN描述 ValueType 类:提供值类型的基类 命名空间: System 程序集: mscorlib.dll 继承关系: 值类型包括:字符.整数.浮点.布尔.枚举.结构(其实字符.整数 ...
- 类库探源——System.Environment
Environment 类: 提供有关当前环境和平台的信息以及操作它们的方法.此类不能被继承. 命名空间: System 程序集: mscorlib.dll 继承关系: 常用属性(字段)和方法: ...
- 类库探源——System.String
一.MSDN描述 String 类: 表示文本,即一系列的 Unicode 字符 命名空间 : System 程序集 : mscorlib.dll 继承关系: 备注: 1. 字符串是 Unicode ...
- 类库探源——System.Type
一.MSDN 描述 Type 类:表示类型声明:类类型.接口类型.数组类型.值类型.枚举类型.类型参数.泛型类型定义.以及开放或封闭构造的泛型类型. 命名空间: System 程序集:mscorlib ...
随机推荐
- poj 2586 Y2K Accounting Bug
http://poj.org/problem?id=2586 大意是一个公司在12个月中,或固定盈余s,或固定亏损d. 但记不得哪些月盈余,哪些月亏损,只能记得连续5个月的代数和总是亏损(<0为 ...
- [转]NHibernate之旅(7):初探NHibernate中的并发控制
本节内容 什么是并发控制? 悲观并发控制(Pessimistic Concurrency) 乐观并发控制(Optimistic Concurrency) NHibernate支持乐观并发控制 实例分析 ...
- 解决 VirtualBox 安装windows 8.1 Preview OR Server 2012 R2 Preview 错误
安装windows 8.1 Preview 或 Server 2012 R2 Preview时提示错误 Your PC needs to restart 解决方法: 在cmd中输入以下代码执行即可: ...
- Linux,实时获取磁盘空间
#include <iostream> #include <stdlib.h> #include <stdio.h> #include <sys/statfs ...
- 【转】谁说Vim不是IDE?(三)
谁说Vim不是IDE?(三) 常用插件 之所以说Vim形成了自己的生态环境,就是因为Vim具备开放的插件体系,开发者为了提升开发效率,为Vim编写了数以万计的插件,我们可以根据需要任意选择,也可以 ...
- KMP算法(模板)
话说kmp真的挺难理解的,花了挺大功夫的,恩,找了段好理解的代码,做模板了 int KMP(char *s,char *p){ int ans = -1; nex[0] = 0; int lenp = ...
- EXCEL 2010学习笔记—— 动态图表
今天梳理一下动态图表的相关内容,做一个简单的整理 关键的操作点: 1.插入动态控制器:开发工具->插入->表单控件 对控件进行修改 右键 设置控件格式->单元格链接 用来作为if ...
- Guava库
Guava是一个非常棒的库,它就是Java标准库"所缺失的那部分",是一个 Google 的基于java1.6的类库集合的扩展项目,包括 collections, caching, ...
- 理解事件捕获。在限制范围内拖拽div+吸附+事件捕获
一.实现的效果是在限制范围内拖拽div+吸附+事件捕获. 这里需要理解的是事件捕获,这个事件捕获也是为了兼容div在拖拽过程中,文本不被选中这个问题. 如此良辰美景,拖拽也可以很洒脱哈.先看看图, 二 ...
- C语言之void类型及void指针 分类: C/C++ 2015-07-13 11:24 8人阅读 评论(0) 收藏
原文网址:http://www.cnblogs.com/pengyingh/articles/2407267.html 1.概述 许多初学者对C/C 语言中的void及void指针类型不甚理解,因此在 ...