首页 > 作文

总结C#处理异常的方式

更新时间:2023-04-04 07:08:05 阅读: 评论:0

关于异常,从我们一开始写代码的时候就开始伴随着我们,只不过那时还没入门,脑子里并没有产生意识这就是异常。

异常:程序运行期间发生错误,

异常对象: 将程序发生的各种错误封装成对象

曾记得第一次面试的时候,面试官问了我这样的一个拐弯的问题“你平时是怎么解决出现的各种问题”,a:当时心中一惊,看别人的面经也提到了这个问题,没有多想“首先自己找找看哪里出了出的错误,定位感恩节祝福经典语录到出现错误的位置,看出现了什么异常”。q:那你说说有哪些异常,,产生异常的原因,如何处理的。a:空指针,超出索引异常,en en………当时挺尴尬,问到了异常我却回答这么简单,缺乏思考。

在实际的工作中,捕获异常,收集分析异常对于解决问题至关重要。

exception类分析

systemexception类继承exception,前者是system命名空间中所有其他异常类的基类,在捕获异常的时候,我首先查看的就是exception对象信息。exception重要成员如下图

这里写图片描述

1.message属性:产生异常原因的错误消息
[__dynamicallyinvokable]public virtual string message{    [__dynamicallyinvokable]    get    {        if (this._message != null)        {            return this._message;        }        if (this._classname == null)        {            this._classname = this.getclassname();        }        return environment.getruntimeresourcestring("exception_wasthrown", new object[] { this._classname });    }}

message属性是只读属性,getruntimeresourcestring是获取运行时资源字符串。返回的字符串是产生异常原因的错误消息或者空字符串。

2.data:的其他异常信息的键/值对的集合
public virtual idictionary data {              get {                if (_data == null)                   if(isimmutableagileexception(this))                            _data = new emptyreadonlydictionaryinternal();                  el         _data = new listdictionaryinternal();                 return _data;             }         }
3.stacktrace:出现异常之前调用的方法名称和签名
public static string stacktrace{    [curitysafecritical]    get    {        new environmentpermission(permissionstate.unrestricted).demand();        return getstack少先队基本知识trace(null, true);    }}
4.source属性:包含生成异常的应用程序或对象的名称5.targetsite属性:引发当前异常的方法6.getbaexception方法 :返回system.exception,它是所有异常类的“基”类。

常见的异常类

异常类型有很多,他们都是继承自systemexception,这些异常类型大概分为以下这几种1.与数组集合有关2.与成员访问有关3.与参数有关4.与算术相关5.io相关6.当然还有其他的一些异常。

1.与数组集合有关

indexoutofrangeexception类:索引超出范围引发的异常arraytypemismatchexception类:数组集合存储数据类型不正确引发的异常rankexception类:处理维数错误引发的异常

2.io有关的异常

与io相关的异常都继承自ioexception类,该类用于处理进行文件输入输出操作时所引发的异常,ioexception类的5个直接派生类如下。

directorynotfoundexception类:没有找到指定的目录而引发的异常。filenotfoundexception类:没有找到文件而引发的异常。endofstreamexception类:处理已经到达流的末尾而还要继续读数据而引发的异常。fileloadexception类:无法加载文件而引发的异常。pathtoolongexception类:文件名太长而引发的异常。

3.成员访问有关的异常

与成员访问相关的异常都继承自memberaccesxception这个类,它继承自systemexception。

fileaccesxception:访问字段成员失败所引发的异常methodaccesxception:访问方法成员失败引发异常missingmemberexception:成员不存在引发的异常

4.参数相关的异常

与参数有关的异常类argumentexception都继承自systemexception,处理给方法成员传递参数时发生异常

argumentoutofrangeexception:当一个参数不在给定范围内引发的异常argumentnullexception:参数为null(不允许null)的情况下引发的异常

5.与算术相关

arithmeticexception异常类用于处理与算术相关的异常,它的相关子类如下

dividebyzeroexception:整数十进制试图除以0引发的异常(被除数不能为0)notfinitenumberexception:浮点数运算中出现无穷大或非负值引发的异常

6.其他异常

nullreferenceexception:当一个对象没有实例化时并引用引发的异常invalidoperationexception:当对方法的调用对象当前状态无效时引发异常invalidcastexception:处理类型转换期间引发的异常outofmemoryexception:处理内存不足引发的异常stackoverflowexception:处理栈溢出引发的错误

异常捕获

c#中提供try 和catch块提供了一种结构化的异常处理方案,所有可能出现的异常都必须得到妥善的处理,try catch本身并不会影响系统的性能,在没有发生异常的时候try catch 是不会影响系统性能的。受影响的时候是发生异常的时候。

关键字 try catch finally。先执行try里面的语句,如果抛出异常就会被catch捕获。无论出不出现异常都会执行finally里面的语句。另外不常用的throw关键字:当问题出现时,程序抛出一个异常。

class program    {        static void main(string[] args)        {            dividenumber div = new dividenumber();            div.dividemethod(2, 0);            console.readkey();        }    }    class dividenumber    {        int result;        public dividenumber()        {            result = 0;        }        public void dividemethod(int a,int b)        {            try            {                result = a / b;            }            catch (dividebyzeroexception e)            {                console.wr苏格拉底 老婆iteline("exception,被除数不能为0,e.message:" + e.message);            }            finally {                console.writeline($"{a}除以{b}的结果是"+result);            }        }    }

异常处理原则和建议

在实际的开发中,异常到底需要怎么写,还是和系统的稳定性和容错性有一定要求的。

要捕获具体的异常

在捕获异常的时候,我们经常习惯性写catch(exception ex) ,这个并非具体的异常,最好是能具体到argumentexception、formatexception等异常类,不要抛出”new exception()”

catch中啥也不干,异常要向顶层抛出

这种情况在自己写demo的时候可能比较常见,在编写catch(exception ex)这块代码下啥也不干,不要这样做。切记出现的异常要想顶层抛出

合理使用finally块

finally关键字是不管抛出什么类型异常都会被执行,大多数的时候能在finally块下执行的代码,也能写在catch里面。那么finally关键字到底在什么情况下使用比较合适呢,比如清理资源,关闭流,回复状态等。

抛出的异常要记录下来

当然程序中出现的异常并不是所有都要记录下来,有些异常还是记录下来便于分析具体的问题。一些记录日志库 log4net ,eif……

不要只记录exception.message的值,还需要记录exception.tostring()

刚刚前面的例子,我打印的e.message ,仅仅只是输出“尝试除以0”,提示的错误信息不具体,并不推荐这样做。tostring方法中包含了stacktrace、内部异常信息、message……通常这些锦旗送老师信息比仅一个message更重要

全球化的利与弊不要将“抛出异常”作为函数执行结果的一种

“抛出异常”应该向顶层抛出,但是不能作为方法执行结果的一种,方法的结果不能是异常类。

每个线程要包含一个try/catch块

创建子线程去执行任务时,主线程不会知道子线程的异常情况,所以每个线程都需要一个try、catch.

来自“代码思考者“的评论

之前在做c#项目的项目经理时,我也思考过如何有效地在项目团队中实践异常的处理。

首先,异常处理应该是系统设计规约的一部分出现在系统设计文档中,而不仅仅是一种技术实现。

作为设计文档的一部分,异常处理应该着眼于系统容错性和稳定性(正如楼主提到的那样)。然后在根据这个规约,再来具体讨论和选择异常处理中使用的各种技术细则。

比如,在设计服务时,必须在服务的调用接口处有异常处理,否则客户端传过来的任何有害数据都可能让服务器挂掉。

比如,对异常的处理在系统的设计中,必须有明确说明,不能随便在哪个模块中处理异常。

以上是我的个人经验,还望走过的朋友多多交流。

到此这篇关于总结c#处理异常方式的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

本文发布于:2023-04-04 07:08:03,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/4a5e7d8a6a835734f47b3b77834d2b82.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:总结C#处理异常的方式.doc

本文 PDF 下载地址:总结C#处理异常的方式.pdf

标签:异常   抛出   方法   成员
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图