错误处理的一点思考
“世界上并不存在完全无错的程序”,我们不讨论它是不是一条真理。但它的确是一条警语,它告诫我们在编写程序时一定要注意尽可能地避免错误。
程序运行出错时会超出程序员的控制,使得程序“南辕北辙”,不仅无法正常完成功能,而且还会出现一些可怕的事情。
由于程序设计的错误而引起的事故数不胜数,损失最巨大的是美国的一次火箭发射,在那次悲剧中,在程序中由于错把“,”写成了“;”,却使得火箭在天上爆炸,所以为防止程序设计错误花再大的人力、物力也是应该的。
以上这段话说明了错误处理的重要性。
最有效的解决方法是在程序设计是,有意识地加入一些机制,使其能够在运行时检测自己,在错误失控之前,报告出来。
最常见的一种错误处理是为每一个方法(其它语言,就是每一个函数)返回一个状态值,用来指示该方法是否成功、正确地完成了任务。当调用这个方法的程序收到了一个错误的状态值,就能够得知程序出错了,再采取有效的措施避免这个错误引起的问题(最简单的方法就是退出程序,或给出提示提醒操作者)。
首先让我引入一个概念:错误模式
所谓的错误模式,我理解和设计模式所涉及到的知识应该是一样的,错误模式就是已发出的错误和程序中潜在的错误之间的重复出现的相互关系。这种概念对编程来说并不是新鲜的,随便极端编程的出现,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