zoukankan      html  css  js  c++  java
  • Best Practices for C# Exception Handling

    The C# error handling knowledge pack contains preconfigured rules based on the .NET Error Raising and Handling Guidelines found in Microsoft's C# Design Guidelines for Class Library Developers, .NET Best Practices for Handling Exceptions found in the .NET Framework developers guide as well as other industry best practices.  These rules are highly configurable and offer the ability to define your own best practices.
     
    Rule
    Description
    Automatic Correction
    Handled Exceptions should be published
    When exceptions are handled in try catch block, the information should be published to a system log and/or to the user.  This rule detects and implements publishing based on your needs.  These include EventLog, AssertDebug, MessageBox.Show and Microsoft's Exception Management Application Block as well as custom event publishing methods.
    Yes
    Specific call requires a try/catch block
    Enforces the requirement that certain calls have a try/catch block around them.  This rule allows you to define under what circumstances you should use a try/catch block.  Examples include references to certain objects, calls to certain methods or encapsulating specific methods with centralized exception handling.
    No
    Method requires tracing implementation
    Enforces the requirement that specific methods have enter/leave tracing implemented.  This rule makes it easy to completely add or remove instrumentation from your solution using the Trace class.
    Yes
    ArgumentException should be used if invalid parameters are passed.
    Exceptions of type System.ArgumentException should be thrown when an invalid argument has been passed into a method.  These include:
    System.ArgumentException
    System.ArgumentNullException
    Yes
    Do not create methods that throw IndexOutOfRangeException
    System.IndexOutOfRangeException is a system exception thrown only by the runtime and should not be thrown by application code.
    Yes
    Do not create methods that throw System.Exception
    System.Exception is a base class for subclassing all exceptions and should therefore not be used directly.
    Yes
    Do not create methods that throw System.NullReferenceException
    System.NullReferenceException is a system exception thrown only by the runtime and should not be thrown by application code.
    Yes
    Do not create methods that throw System.Runtime.InteropServices.ExternalException
    ExternalException is a base class for subclassing COM Interop exceptions from and should therefore not be thrown directly.
    Yes
    Do not create methods that throw System.SystemException
    System.SystemException is a base class for subclassing all system exceptions and should therefore not be thrown directly.
    Yes
    Localize strings for any exception messages
    Localize any public facing exception strings by putting the message strings in a resource file.  This rule will automatically localize the string, create the resource and make the call to Resources.ResourceManager
    Yes
    Test for Null argument before referencing
    It is good practice to test method arguments for null before referencing, and if they are null throw an ArgumentNullException.  This can provide more detailed information in cases where an unexpected error occurs.  If this is not done the exception may be a NullReferenceException with very little information available. 
    Yes
    Re-throw should not throw with argument.
    Do not re-throw the same exception using the exception argument in the throw statement.  A try catch block that throws with the argument causes the loss of the original stack trace when the Exception.StackTrace method is called.
    Yes
    Exception class names must end in the word "Exception"
    Exception classes, those that inherit either directly or indirectly from System.Exception, should be suffixed with the word "Exception".  This rule understands common misspellings and other suffixes such as "Error", "Warning", etc.
    Yes
    Exception classes Must Be Marked Serializable
    In order to work properly in all scenarios, user-defined exceptions must be serializable and have the System.Serializable attribute.
    Yes
    Should not inherit directly from System.Exception
    System.Exception is a base class for subclassing all exceptions in the .NET framework and should not be inherited from directly to create user-defined exceptions.
    Yes
    Should not inherit indirectly from System.SystemException
    System.SystemException is a base class for subclassing all system exceptions in the .NET framework and should not be inherited from directly to create user-defined exceptions.
    Yes
    Use the three common constructors when creating Exception classes
    It is a good practice when creating user-defined exception classes to implement the three common constructors.
    Yes

    作者:Angelo Lee
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
  • 相关阅读:
    asp.net(c#)网页跳转七种方法小结
    asp.net用Zxing库实现条形码输出的具体实现
    SQL中 patindex函数的用法
    escape()、encodeURI()、encodeURIComponent()区别详解
    sql语句分页代码
    memcache安装
    LVS和Haproxy机器必须注意的几个参数
    Redis 三主三从集群搭建
    mogodb安装步骤及注意事项
    系统故障等级和故障报告规定
  • 原文地址:https://www.cnblogs.com/yefengmeander/p/2887682.html
Copyright © 2011-2022 走看看