错误处理的一点思考

原创 2003年08月20日 10:40:00

错误处理的一点思考<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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

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

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

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

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

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

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

所谓的错误模式,我理解和设计模式所涉及到的知识应该是一样的,错误模式就是已发出的错误和程序中潜在的错误之间的重复出现的相互关系。这种概念对编程来说并不是新鲜的,随便极端编程的出现,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方式处理,这种方式我以前在写程序的时候就在用,现在又搬出来希望能听到回复的声音,讨论一下,看一看有没有更好的解决方式,由于本人水平有限,目前的错误处理设计依然是基于这个去做的。

欢迎mail讨论:biggie@designac.com

错误处理的一点思考

“世界上并不存在完全无错的程序”,我们不讨论它是不是一条真理。但它的确是一条警语,它告诫我们在编写程序时一定要注意尽可能地避免错误。 程序运行出错时会超...
  • www_extract_com_cn
  • www_extract_com_cn
  • 2006年12月26日 16:58
  • 461

运营一点思考

今天阅读互联网运营书籍的时候,忽然看到作者分享了一个案例,主要讲用户群的消息推送问题。作者是做课程培训的,有学员群,作者的同事在群中推送了一条消息,主要是介绍课程的信息,内容大致主要是有哪些领域中的大...
  • leanln
  • leanln
  • 2018年01月08日 23:41
  • 25

net错误处理机制

 没有不出错的软件        从不出错的软件从某种程度上讲是不可能的!       和普通人的观念相反,创造可信赖的,健壮的软件并不是一件不可能的事情。大部分的商业软件,在长时间可...
  • yulongguiziyao
  • yulongguiziyao
  • 2013年11月27日 10:30
  • 713

.net的错误处理机制是什么?

.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。...
  • sinat_27305053
  • sinat_27305053
  • 2017年04月13日 17:07
  • 1101

一点思考

一直想写点东西来总结下最近遇到的问题,记录期间采用的方法。回首下来,这种分析、解决问题的过程总是让人进步很大!          最近一直在实验室做三维网格图形骨骼化提取,原本计划是要半个月完成的,可...
  • sgs1018
  • sgs1018
  • 2013年11月18日 00:06
  • 673

读《面向对象的思考过程》作者matt Weisfeld

最近接触了很多java代码,开始于机缘巧合,读了《java编程思想》的大概前四分之一,这比我读《C++primer》还要多了,两本都是大部头,我能完整读完还需毅力。惊讶于两门语言语法非常的相似,之前对...
  • czl389
  • czl389
  • 2017年02月22日 11:36
  • 1084

怎样做一个有想法的人-《思考的艺术》读后感

最近看了一本书《思考的艺术》,书中主要讲的是教人如何思考,如何做一个有观点和善于独辟蹊径的人。作者在书中提到创造性和批判性思维方式不是与生俱来的,与具体的智商关系也不是很大,而是有规律可循的,可通过后...
  • ennaymonkey
  • ennaymonkey
  • 2017年11月23日 15:53
  • 447

一点思考··

从早上6.30起床到中午不睡觉,一直到晚上11.30睡觉已经坚持了一个星期了,也学了点东西,很少的一点,到第二周感觉自己做的是无用功,东西一点没记住,只记住了一点英语,还有一点知识,不知道为什么,总感...
  • qq_24085431
  • qq_24085431
  • 2016年03月14日 12:59
  • 179

关于httpclient的一点错误处理

java.lang.NoSuchMethodError: org.apache.commons.httpclient.HttpClient.getParams()Lorg/apache/commons...
  • linuxchyu
  • linuxchyu
  • 2013年06月21日 23:04
  • 1088

2011年终工作总结与思考

2011年已到尾声,在这最后的几天里,我需要的是认真思考、总结一下今年的工作。     今年的事情比较专一,我一直在开发,其实很喜欢这种从头到尾做一件事情的感觉,比起东跑西颠,至少能在某一方面,有一...
  • BeyondHaven
  • BeyondHaven
  • 2011年12月20日 17:18
  • 5910
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:错误处理的一点思考
举报原因:
原因补充:

(最多只允许输入30个字)