搜索
首页后端开发C#.Net教程.net及其他架构中异常 (Except) 设计准则的详细介绍

前沿

  异常设计准则,参考微软msdn,结合自己的理解和过去的开发中对异常错误的处理,总结下软件开发架构,如何更好地设计一套异常错误准则。

介绍准则

execution failure概念

The meaning of execution failure: execution failure occurs whenever a member cannot do what it was designed to do (what the member name implies). For example, if the OpenFile method cannot return an opened file handle to the caller, it would be considered an execution failure.

翻译:

操作失败的意思:无论什么时候一个成员模块不能完成它预期的任务时,就称为发生了一次操作失败。例如OpenFile方法不能给caller返回一个打开文件的句柄,这就是一次操作失败。

架构中处理异常

In the Framework, exceptions are used for all error conditions, including execution errors.

翻译:

在框架中,异常被用来处理所有的错误条件,包括执行错误。

总结准则

  哪些方法在设计异常时应该被禁止,哪些应该要without hesitation to do,哪些需要考虑,都列在下方的表格中。

编号 方法 做法
1 返回错误代码 禁止
2 执行错误,要抛出异常;如OpenFile()未返回文件句柄 建议
3 假如代码再继续执行就变得不安全时,考虑是调用System.Environment.FailFast终止进程还是抛异常。 考虑
4 如果有可能的话,在正常的控制流处,抛异常,见下面的分析 禁止
5 抛异常对性能的影响。 考虑
6 协定中纳入异常处理部分 建议
7 将异常作为返回值返回 禁止
8 使用异常生成器方法,为避免代码膨胀, 用helper方法创建异常和属性. 考虑
9 异常筛选器中抛出异常. 禁止
10 从finally 块中显示地抛出异常 禁止

  
  对第4条做说明:

In daily coding, consider the Tester-Doer pattern for members that may throw exceptions in common scenarios to avoid performance problems related to exceptions. The Tester-Doer pattern pides a call that might throw exceptions into two parts: a Tester and a Doer. The Tester performs a test for the state that can cause the Doer to throw an exception. The test is inserted just before the code that throws the exception, thereby guarding against the exception. 来自http://www.php.cn/

  参考的例子代码:

Tester和Doer各司其职,完美的减少了异常抛出,提升性能。
Doer:上面的状态监测是好的,才能DoProcess()处理;如果是false,并且如果DoProcess()中包括DoCheck()逻辑,则会抛出异常,但是这样分隔开后,DoProcess()将不会抛出异常!

if(DoCheck()==true)//这是Tester:状态监测
    DoProcess();

  软件开发常见异常及处理方式(自己总结)

1 UI层暴露出的操作接口,建议包裹try{}catch{}块,catch中将抛出的异常写入到磁盘中。

2 UI层中用到计时器时,计数器的回调函数出现异常后,要stop掉计时器,防止错误日志一直写进文件中。

3 底层建议不包裹try{}catch{}块,建议用throw直接抛出异常,因为UI层上包裹了try{}和catch{}块,所以没必要写在这些层。

4 throw会直接中断以后操作,跳转到所属堆栈外层包裹try{}和catch{},即UI层,利用这个性质,一般建议函数不要返回错误码

5 处理批量导入的数据时,局部出现异常。Excel导入人员,设备,计划,物料,工艺等,如果某一行数据违规了,这时候不建议抛出异常,因为一旦抛出异常,意味着后面行的数据导入不进来,并且已经导入进去的成为脏数据。
  一般有两种做法:某行出现违规数据,记录到日志文件中,日后根据这个文件查到那条数据未导入,然后单独处理这一条即可;在导入前,直接检查所有行的数据是否合法,检查无误后,再一一导入,否则直接弹出提示,任何数据都写不到数据库中。一般建议后者做法。这种做法称为:Tester-Doer异常模式,也是微软建议的做法。

6 处理看板展示数据,局部出现异常。这个处理模式跟5是有区别的,一般此时出现异常,往往采取5的前者做法:展示出正确的数据,违规的数据写入到日志中,留待查看;但是也有可能,如果展示的界面,主要的数据不存在,则直接抛出异常,写入日志,通过日志解决。因此要根据数据的异常严重程度去处理。

7 根据开发文档、日志,分析,尽量做到能够找到某个功能未实现的原因。首先要保留好开发文档,查看用户现在的要求是不是和开发文档中的一致。如果一致,此时日志的作用就显示出来了,例如,汇总一周内所有工序的完工饼状图,如果一条工序数据都没有,那么饼状图可能就没有,在开发过程中,如果检查了是不是存在工序,如果没有找到一条工序,可能会抛出异常,然后写入日志地话,原因就会找到。因此这类问题,也要写入日志,尽管它不是错误,但可以归为异常。

8 函数返回一个对象,其方法和属性被后续逻辑引用。这是不可避免的!并且大部分功能的实现都依赖于此。返回的这个对象因为要被后续引用,所以建议做null比较,如果为null,是传递给UI层,弹出消息提示,还是直接抛出异常,UI层处理后写入日志,视情况而定。

 以上就是.net及其他架构中异常 (Except) 设计准则的详细介绍的内容,更多相关内容请关注PHP中文网(www.php.cn)!


声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
C#.NET:探索核心概念和编程基础知识C#.NET:探索核心概念和编程基础知识Apr 10, 2025 am 09:32 AM

C#是一种现代、面向对象的编程语言,由微软开发并作为.NET框架的一部分。1.C#支持面向对象编程(OOP),包括封装、继承和多态。2.C#中的异步编程通过async和await关键字实现,提高应用的响应性。3.使用LINQ可以简洁地处理数据集合。4.常见错误包括空引用异常和索引超出范围异常,调试技巧包括使用调试器和异常处理。5.性能优化包括使用StringBuilder和避免不必要的装箱和拆箱。

测试C#.NET应用程序:单元,集成和端到端测试测试C#.NET应用程序:单元,集成和端到端测试Apr 09, 2025 am 12:04 AM

C#.NET应用的测试策略包括单元测试、集成测试和端到端测试。1.单元测试确保代码的最小单元独立工作,使用MSTest、NUnit或xUnit框架。2.集成测试验证多个单元组合的功能,常用模拟数据和外部服务。3.端到端测试模拟用户完整操作流程,通常使用Selenium进行自动化测试。

高级C#.NET教程:ACE您的下一次高级开发人员面试高级C#.NET教程:ACE您的下一次高级开发人员面试Apr 08, 2025 am 12:06 AM

C#高级开发者面试需要掌握异步编程、LINQ、.NET框架内部工作原理等核心知识。1.异步编程通过async和await简化操作,提升应用响应性。2.LINQ以SQL风格操作数据,需注意性能。3..NET框架的CLR管理内存,垃圾回收需谨慎使用。

C#.NET面试问题和答案:提高您的专业知识C#.NET面试问题和答案:提高您的专业知识Apr 07, 2025 am 12:01 AM

C#.NET面试问题和答案包括基础知识、核心概念和高级用法。1)基础知识:C#是微软开发的面向对象语言,主要用于.NET框架。2)核心概念:委托和事件允许动态绑定方法,LINQ提供强大查询功能。3)高级用法:异步编程提高响应性,表达式树用于动态代码构建。

使用C#.NET建筑微服务:建筑师实用指南使用C#.NET建筑微服务:建筑师实用指南Apr 06, 2025 am 12:08 AM

C#.NET是构建微服务的热门选择,因为其生态系统强大且支持丰富。1)使用ASP.NETCore创建RESTfulAPI,处理订单创建和查询。2)利用gRPC实现微服务间的高效通信,定义和实现订单服务。3)通过Docker容器化微服务,简化部署和管理。

C#.NET安全性最佳实践:防止常见漏洞C#.NET安全性最佳实践:防止常见漏洞Apr 05, 2025 am 12:01 AM

C#和.NET的安全最佳实践包括输入验证、输出编码、异常处理、以及身份验证和授权。1)使用正则表达式或内置方法验证输入,防止恶意数据进入系统。2)输出编码防止XSS攻击,使用HttpUtility.HtmlEncode方法。3)异常处理避免信息泄露,记录错误但不返回详细信息给用户。4)使用ASP.NETIdentity和Claims-based授权保护应用免受未授权访问。

c语言中:是什么意思c语言中:是什么意思Apr 03, 2025 pm 07:24 PM

C 语言中冒号 (':') 的含义:条件语句:分隔条件表达式和语句块循环语句:分隔初始化、条件和增量表达式宏定义:分隔宏名和宏值单行注释:表示从冒号到行尾的内容为注释数组维数:指定数组的维数

c语言中a  是什么意思c语言中a 是什么意思Apr 03, 2025 pm 07:21 PM

C 语言的 a 是后增运算符,其运作机制包括:先获取变量 a 的值。将 a 的值增加 1。返回自增后的 a 的值。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器