`
seeglow
  • 浏览: 53716 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

错误处理规范

阅读更多

一、整体规范

1.      按照错误类型,通常的处理方式如下:

 

错误类型

范围

处理方式

操作员错误

与人机界面交互时不满足输入规则、输入范围等发生的错误

校验用户输入

提示正确规则

强制其改正

运行时错误

与外部资源交互时发生的错误,如网络、文件系统、数据库、其它业务应用系统等

记录并抛出异常

其它详见“异常处理规范”

程序员错误

与客户模块交互时不满足前置条件后置条件发生的错误,如类库被其他程序员调用时参数超出范围等

使用断言

2.      按照调用类型,通常的处理方式如下:

 

调用类型

处理方式

同步调用

  • 对有能力处理的异常,捕获并处理之
  • 对原始信息过于技术化的异常,捕获并包装之,重新抛出
  • 在调用的中间层,对未知异常保持沉默
  • 在调用的最高层,必须捕获所有异常,避免本身进程或宿主进程崩溃
  • 其它详见“异常处理规范”

异步调用

  • 异步调用一般不应有任何返回值
  • 服务方最好以同样的方式返回正常信息和错误信息,即正常信息是通过通知的方式返回的话,错误信息也应该通过通知的方式返回;正常信息是通过主动查询得到的话,错误信息也应该通过主动查询得到

 二、异常处理规范

 异常应该是分层的

 1. 异常定义

  • 每个模块应该有自己的应用程序异常类型层次,从本模块主动抛出的应用程序异常都应该属于该异常类型层次,客户代码可以只捕捉该层次的基类(?)
  • 应用程序的所有自定义异常都应该从开发平台提供的“应用程序异常基类”派生
  • 中间件等平台程序的运行时异常都应该从开发平台提供的“运行时异常基类”派生(?)
  • 中间件等平台程序的运行时错误都应该从开发平台提供的“错误基类”派生(?)

 2. 异常捕获

  • 对有能力处理的异常,捕获并处理之
  • 在调用的中间层,对未知异常保持沉默
  • 在调用的最高层,必须捕获所有异常,避免本身进程或宿主进程崩溃
  • 记录捕获到的每个原始异常的信息

 3. 异常抛出

  • 每个模块应使用本模块所能得知的最精确的错误原因报告异常信息
  • 如果有原始异常,在重新抛出的自定义异常中附加原始异常的信息

 三、几点说明

 

 1. 错误处理与日志系统

  • 错误处理不等同于日志系统,日志系统只是错误信息的一种记录手段
  • 错误信息的输出应全部调用日志系统来完成

 2. 程序员错误与运行时错误

  • 接口函数的前置条件,应该是一种规范,是客户程序员必须遵守的约定;客户程序员违反了约定,程序将产生异常或不可预知的错误;对于这类约定,不应该需要有运行时的代码检查 ;比如如果你的接口函数的一个参数不能为null,而你在函数开始部分程序里写:

         if(xxx == null){

              throw new someException();

}

你的代码实际上允许该参数为null,因为你对null的情况进行了运行时处理;尽管你在文档里声明该参数不能为null,但如果客户程序员遵守了约定,那么你这段检查代码就是冗余的

  • 当你对参数没有任何检查就进行了使用,而非法的参数值导致了错误,此时有两种情况: 如果你在接口函数说明里列出了参数不允许的非法取值,那么客户程序员应该修改程序避免传入非法值,该类错误称为程序员错误;如果你没有说明,那么你应该修改函数,处理非法参数
  • 不是所有的限制条件在文档里说明一下,就可以把责任扔给客户程序员了,有一些错误必须处理:特别是客户程序员不需要import你的package就可以和你的接口交互的情况,如socket服务器 ,你必须在socket服务程序内部检查所有接收到的数据,拒绝错误的请求,否则极易遭到攻击

 3. 错误代码与异常

  • 不应该使用bool值来返回成功与否,bool返回值只应用在真正查询bool状态的操作中,如 bool IsDirty()bool hasNext()
  • 整形或bool型的错误代码返回值强迫客户程序员检查每一次调用,应用异常取代之

 

世界上并不存在完全无错的程序,我们不讨论它是不是一条真理。但它的确是一条警语,它告诫我们在编写程序时一定要注意尽可能地避免错误。

程序运行出错时会超出程序员的控制,使得程序南辕北辙,不仅无法正常完成功能,而且还会出现一些可怕的事情。

由于程序设计的错误而引起的事故数不胜数,损失最巨大的是美国的一次火箭发射,在那次悲剧中,在程序中由于错把写成了,却使得火箭在天上爆炸,所以为防止程序设计错误花再大的人力、物力也是应该的。

以上这段话说明了错误处理的重要性。

  最有效的解决方法是在程序设计是,有意识地加入一些机制,使其能够在运行时检测自己,在错误失控之前,报告出来。

最常见的一种错误处理是为每一个方法(其它语言,就是每一个函数)返回一个状态值,用来指示该方法是否成功、正确地完成了任务。当调用这个方法的程序收到了一个错误的状态值,就能够得知程序出错了,再采取有效的措施避免这个错误引起的问题(最简单的方法就是退出程序,或给出提示提醒操作者)。

首先让我引入一个概念:错误模式

所谓的错误模式,我理解和设计模式所涉及到的知识应该是一样的,错误模式就是已发出的错误和程序中潜在的错误之间的重复出现的相互关系。这种概念对编程来说并不是新鲜的,随便极端编程的出现,RUP,单元测试只能解决一部分存在的问题,所以我们采用错误模式,一个错误的出现,只要遵循我们可以识别的错误模式中的一种,随可以得知这个错误的原因并且纠正它。

有兴趣的朋友可以搜搜错误模式,有许多文章介绍的。以下是我要介绍的二种错误处理方式。

一 构造错误异常:

构造错误异常,这里就利用了错误模式去发现错误并纠正它,首先让看一段代码:

InvalidNameException.java

class InvalidNameException extends Exception{
    public InvalidNameException(){
    }
}

程序中:

public User validate(String userName,String password) throws InvalidNameException{
        if(userName.equals("java")){
        }else{
            throw new InvalidNameException();
        }
        //return null;
    }

以上这段代码,意思就是,如果用户名不为java的话,那么就抛出InvalidNameException()这个异常,于是我们就可以成功的捕捉这个异常,并发出提示或警告。这样构造一个强大的错误处理集合就可以对程序内部或外部进行错误处理。

 key/values方式.

    根据配置文件查找相应的错误信息,并显示给用户,struts的错误处理方式就采用了这个(其实我说的二种都采用了)。首先看一下以下代码:

ErrorMessage error=new ErrorMessage();
if(!username.equals(“java”)){
    error.add(“ERROR.LOGIN.USERNAME.FAILED”);
}

    创建一个ErrorMessage对错误进行处理,如果返回空的error对像的话,说明没有错误,如果返回一个非空的error对像,那么就跳转到error.jsp页面,并捕捉这个错误。

错误信息配置文件:

LOGIN = 用户登陆

ERROR.LOGIN.EMPTY_INPUT = 登陆失败:无效输入!

ERROR.LOGIN.EMPTY_INPUT.DESC = 可能输入了空值或其他非法字符。

ERROR.LOGIN.USERNAME.FAILED = 用户名错误

ERROR.LOGIN.USERNAME.DESC = 请后退重试,检查您的用户名是否输入正确!

以上两种方式结合于log4j一起使用,可以达到对错误处理的要求,我的思想就是在系统层,如方法内,抛出异常处理,在表现层对用户输入和相关处理用key/values方式处理,这种方式我以前在写程序的时候就在用,现在又搬出来希望能听到回复的声音,讨论一下,看一看有没有更好的解决方式,由于本人水平有限,目前的错误处理设计依然是基于这个去做的。

 

 

分享到:
评论

相关推荐

    JAVA的错误处理规范,很实用

    JAVA的错误处理规范,很实用-JAVA standardized error handling, very practical.zip

    【软件测试】: 单元测试:模块接口、局部数据结构、路径、边界条件、错误处理、代码书写规范.doc

    【软件测试】: 单元测试:模块接口、局部数据结构、路径、边界条件、错误处理、代码书写规范.doc

    《C++编程规范101条规则、准则最佳实践》中文版

    从类型定义到错误处理,都给出了最佳的C++实践。即使使用C++多年的程序员也会从《C++编程规范:101条规则准则与最佳实践》中受益匪浅。《C++编程规范:101条规则准则与最佳实践》适合于各层次C++程序员使用,也可作为...

    OWASP安全编码规范1

    2012 年 8 月目录序言 3软件安全与风险原则概览 4输入验证: 5输出编码: 5身份验证和密码管理: 6会话管理: 7访问控制: 7加密规范: 8错误处理

    C++/C编程规范

    另外还给出了从类型定义到错误处理等方面的大量C++实践,包括许多总结和标准化的技术。即使使用C++多年的程序员也会从中受益匪浅。  通过阅读本书,可以找到以下问题的答案。  哪些东西值得标准化?哪些东西不值得...

    Go编程规范-企业级中文版编程规范-Google.pdf

    该指南包含了编程风格、错误处理、接口设计、测试等多个方面的规范、示例和说明,旨在指导开发人员编写高质量的Go语言代码。 适用人群:适合Go语言开发人员、软件工程师、程序员,以及对Go语言编程规范感兴趣的技术...

    Golang 代码规范

    Golang 代码规范,目录 基础规范 gofmt 项目目录结构 包管理器 注释 命名 错误处理 单元测试 进阶规范 在项目中不要使用相对路径引入包,要用绝对路径 声明slice 非空slice检查 ......

    iOS软件代码规范

    iOS软件代码规范目录 前 言 4 1. 指导原则 5 2. 布局 5 2.1. 文件布局 6 2.2. 基本格式 8 2.3. 对齐 9 2.4. 空行空格 11 2.5. 断行 13 3. 注释 14 4. 命名规则 17 4.1. 基本规则 17 ...10. 断言与错误处理 32

    java代码规范

    没有规范的对输入输出参数的规范,没有规范的异常处理,没有规范的日志处理等等,不但导致了我们总是出现类似空指针这样低级的bug而且还很难找到引起bug的原因。相反,在规范的开发中,bug不但可以有效减少,查找bug...

    C++ 编程规范

    《C++编程规范:101条规则、准则与最佳实践》中,两位知名的c++专家将全球c++界...从类型定义到错误处理,都给出了最佳的c++实践,即使使用c++多年的程序员也会从《C++编程规范:101条规则、准则与最佳实践》中受益匪浅。

    SVN使用规范.doc

    SVN使用规范,描述SVN使用的相关问题

    安全开发规范手册.docx

    2.1.4. 规范化 5 2.1.5. 净化 5 2.1.6. 合法性校验 6 2.1.7. 防范SQL注入 6 2.1.8. 文件校验 6 2.1.9. 访问控制 6 2.2. 输出验证 6 2.2.1. 概述 6 2.2.2. 编码场景 6 2.2.3. 净化场景 7 2.3. SQL注入 7 2.3.1. 概述 ...

    安全规范细则

    本规范从登录认证、权限控制、数据传输、数据存储、日志审计、错误处理、安全编码几个方面进行规范要求。

    c++编程规范

    本书是两位全球知名的c++专家讲c++界20年的集体智慧和经验凝结...书中对每一条规范都给出了精确地描述,并辅以实例说明,从类型定义到错误处理,都给处理最佳的c+时间。即使使用c++多年的程序员也会从这本书中受益匪浅

    代码规约及数据库设计规范.zip_alivesof_代码 规约 规范

    java开发代码规约,包括注释、命名、错误处理等 数据库设计规范

    C++编程规范

    从类型定义到错误处理,都给出了最佳的c++实践,即使使用c++多年的程序员也会从《C++编程规范:101条规则、准则与最佳实践》中受益匪浅。  《C++编程规范:101条规则、准则与最佳实践》适合于各层次c++程序员使用,也...

    软件编码开发规范(暂行)

    在研究项目团队协作开发的情况下(这里的团队协作也适合于应用项目...本规范由程序风格、命名规范、注释规范、程序健壮性、可移植性、错误处理以及软件的模块化规范等部分组成。 本软件开发规范适合讨论C/C++程序设计。

    APEx:自动生成API函数的错误规范的工具

    APEx:用于生成错误规范的... 但是,手动发现错误规范是一项繁琐的任务,为了使错误处理错误的发现完全自动化,我们也希望自动生成这些规范。 我们使用APEx来推断Libgcrypt,GnuTLS,GTK,libc,OpenSSL和zlib的错误

    ERP操作流程规范

    经帐户持有人同意,操作他人帐户进行数据处理,造成ERP数据错误。由帐户持有人负责。 岗位数据处理同时有两人或两人以上持有(如月结、月报表),互相协商后由一个处理。如未完成由责任人负责。 ERP推行组安排的其它...

Global site tag (gtag.js) - Google Analytics