原创地址:http://www.cnblogs.com/Alandre/(泥沙砖瓦浆木匠),需要转载的,保留下! 文章宗旨:Talk is cheap show me the code.

大成若缺,其用不弊.大盈若冲,其用不穷.

最完满的东西,好似有残缺一样,但它的作用永远不会衰竭;最充盈的东西,好似是空虚一样,但是它的作用是不会穷尽的

Written In The Font

摘要:

学习内容:

思考:

何为异常处理?

异常处理,英文名为exceptional handling, 是代替日渐衰落的error code方法的新法,提供error code 所未能具体的优势。异常处理分离了接收和处理错误代码。这个功能理清了编程者的思绪,也帮助代码增强了可读性,方便了维护者的阅读和理解。

java语言中,异常处理可以确保程序的健壮性,提高系统的可用率.但是java api 提供的异常都是比较低级的,所以有了'提倡异常封装’

提倡异常封装

异常封装有三个优点:  1)提高系统的友好性   2)提高性能的可维护性   3)解决java异常机制自身的缺陷

提高系统的友好性

系统的友好性,就像系统和开发人员等握手与交流.好的系统对象,会展现出交流时候所需要的一切.因此,良好的友好性需要良好的代码告诉开发人员和用户.开发人员要找需要打印出堆栈信息.

show the code:

public void doStuff() throwsMyBussinessException

{try{

InputStream iStream= new FileInputStream("无效文件.txt");

}catch(FileNotFoundException e)

{

e.printStackTrace();throw new MyBussinessException(e);//此处自定义一个MyBussinessException

}

}

::throw new MyBussinessException(e);

在这里,无效文件导致了两点:文件未找到和该业务出现问题.因此,在文件未找到之后我们可以继续根据需要告之其他异常.

提高性能的可维护性

如何提搞可维护性,大家不能一味的进行这样操作,就抛出Exception,这样会导致别人看你的代码完全check不到异常点.下面的代码是不可取的:

public voiddoStuff()

{try{//do something

} catch(Exception e)

{

e.printStackTrace();

}

}

正确的做法是对异常进行分类处理,并进行封装输出.

show the code:

public voiddoStuff()

{try{//do something

}catch(FileNotFoundException e)

{

log.info("文件未找到!文件为:xxx");

}catch(SecurityException e)

{

log.error("无权访问,原因:xxx");

e.printStackTrace();

}

}

catch{}

catch{}

这样子,直接在代码层级上分析即可,代码异常在哪里抛出.维护人员看到这样的异常也会有了准确的判断.

解决java异常机制自身的缺陷

先抛出个问题:例如注册时,要对很多进行检验.像密码,用户名,邮箱…...这样情况下,我们必须要在一个注册方法里面抛出很多个异常.因此,正确的方法是封装异常,建立异常容器,一次性对某对象进行校验,然后返回所有异常.

show the code

异常容器:

importjava.util.ArrayList;importjava.util.List;public class MyException extendsException

{//容纳所有异常

private List causes = new ArrayList();//构造函数

public MyException(List extends Throwable>_causes)

{

causes.addAll(_causes);

}//读取所有的异常

public ListgetExceptions()

{returncauses;

}

}

处理异常:

public static void doStuff() throwsMyException

{

List list = new ArrayList();//第一个逻辑片段

try{//Do Something

}catch(Exception e)

{

list.add(e);

}//第二个逻辑片段

try{//Do Something two

}catch(Exception e)

{

list.add(e);

}//检查是否有必要抛出异常

if(list.size() > 0)

{throw newMyException(list);

}

}

采用异常链传递异常

我们做的JEE项目时候,一般会有三层的结构:持久层,逻辑层,展现层.异常也是如此的,当我们各个层之间传递异常,我们就需要先封装,然后传递.简要的就是采用异常传递异常:

show the code:

[摘自源码分析]

/***

* 执行 SQL 查询。

*

*@paramisCallable : 是否使用 CallableStatment 执行查询

*@paramsql : 查询语句

*@paramparams : 查询参数

*@return结果集

**/

protected List query(booleanisCallable, String sql, Object ... params)

{

List result = new ArrayList();

ResultSet rs= null;

PreparedStatement pst= null;try{

Connection conn=getSession();

pst=JdbcUtil.prepareStatement(conn, sql, isCallable);

JdbcUtil.setParameters(pst, params);

rs=pst.executeQuery();int cols =rs.getMetaData().getColumnCount();while(rs.next())

{

Object[] objs= newObject[cols];for(int i = 0; i < cols; i++)

objs[i]= rs.getObject(i + 1);

result.add(objs);

}

}catch(SQLException e)

{throw newJdbcException(e);

}finally{

JdbcUtil.closeSqlObject(pst, rs);

}returnresult;

}

从中我们可以抽取的看到:

catch(SQLException e)

{throw newJdbcException(e);

}

jdbc执行SQL语句查询的时候,先抛出SQLException ,然后就像一条链一样,下一步告诉别人是JDBC的异常.下面体会经典,休息下:

大直若屈,大巧若拙,大辩若讷。躁胜寒,静胜热,清静为天下正。

最正直的东西,好似有弯曲一样;最灵巧的东西,好似最笨拙的;最卓越的辩才,好似不善言辞一样。清静克服扰动,赛冷克服暑热。清静无为才能统治天下

受检异常尽可能转化为非受检异常

所有受检异常(Checked Exception)是好事,为何要尽可能转化为非,也就是(Unchecked Exception)呢?我的理解是:受检异常威胁到系统的安全性,稳定性,可靠性,正确性时,不能转换为非受检异常.也就是说,其中存在的受检异常有缺点,转换成Unchecked Exception就轻松解决了.

受检异常使接口声明脆弱

show the code:

interfaceUser

{//修改用户名密码,抛出安全异常

public void changePass() throwsMySecurityException;

}

throwsMySecurityException;

这里面不一定只是一个异常,然而定义了异常,会增加了接口的不稳定性,这就存在了面向对象设计的严重亵渎,如果要改变的话,又破坏了封装性.

另外,受检异常还有两个缺点:

受检异常使代码可读性降低

受检异常增加了开发工作量

多使用异常,把性能问题放一边

“性能问题不是拒绝异常的借口” 就当一个常见的登录用例.我们经常会添加一个例外的事件:”连续登录3次登录失败,暂时锁定用户帐号.”这样这个例外的事件就是一个异常处理.

show the code

public voidlogin()

{try{//正常登录

}catch(InvalidLoginNameException e)

{//用户名无效

}catch(InvalidPasswordException e)

{//密码错误

}catch(TooManyLoginsException e)

{//多次登录失败

}

}

这样子一来,代码逻辑很清晰.但是这样子就抛出了一个主意.这样子有代价:

性能比较慢

java的异常处理机制确实比较慢,这个性能慢是相对的.相对那些基础类型:String Integer…等.有人测试结果如下:

测试结果:

(运行环境:xen虚拟机,5.5G内存,8核;jdk1.6.0_18)

(10个线程,创建10000000个对象所需时间)

普通Java对象45284MS

普通java异常205482MS

改进的Java业务异常16731 MS

相当于创建每个异常对象是普通对象的五倍.但是数量级上是 MS,在一个系统中,如此微小的性能消耗是可以允许的.

java web 中的异常处理

经验之谈:”用对了地方就好,用错了地方就不好。”这是我的师傅跟我说的,他教会了很多.太很抽象,我想我会慢慢学会的.

实际J2EE项目中,通常一个页面请求到达后台以后,首先是到MVC中的controller,在controller层会调用业务逻辑层service,而在service层会调用持久层dao进而获得数据,再将获得的数据一层一层返回到controller层,然后通过controller控制层转发到指定页面.

可能存在的异常:

dao层可能会发生SQLException异常

service层可能会发生NullPointException异常,

controller层可能会发生IOException异常,RuntimeException异常

正确的处理方式

根据上面知识的说法:我们该用以下的方法来实现

采用异常链传递异常 [在这里我们举过,DAO层中jdbc操作怎么实现抛异常例子]

show the code:

@RequestMapping(value = "/courseTeacherRelationAdd")public@ResponseBody String courseTeacherRelationAdd(String courseID,String teacherInfoID,CourseTeacherRelation courseTeacherRelation)

{try{int sign =courseTeacherRelationService.saveOrUpdateCourseTeacherRelation(courseID,teacherInfoID,courseTeacherRelation);if( sign ==Constant.RESULT_SUCCESS )return successResponse("保存成功","../courseTeacherRelation/courseTeacherRelations" , "courseTeacherRelations");

}catch(Exception e)

{throw new EntityException("Error! when save the entity",e);

}return failResponse("保存失败");

}

throw new EntityException("Error! when save the entity",e);

这里用了链式异常抛出:EntityException是自定义的异常类:

public class EntityException extendsRuntimeException

{private static final long serialVersionUID = 1L;publicEntityException() {super();

}publicEntityException(String message) {super(message);

}publicEntityException(String message, Throwable cause) {super(message, cause);

}

}

自然还有些什么拦截器抛出异常,在这里就不详细展开讨论了.

Editor's Note

异常对我说:”用对了地方就好,用错了地方就不好。”

java代码异常处理会影响性能_编写高质量代码改善java程序的151个建议——[110-117]异常及Web项目中异常处理...相关推荐

  1. java代码优化的方法和准则_编写高质量代码:改善Java程序的151个建议(第1章:JAVA开发中通用的方法和准则___建议16~20)...

    建议16:易变业务使用脚本语言编写 Java世界一直在遭受着异种语言的入侵,比如PHP,Ruby,Groovy.Javascript等,这些入侵者都有一个共同特征:全是同一类语言-----脚本语言,它 ...

  2. 编写高质量代码改善java程序的151个建议——[110-117]异常及Web项目中异常处理

    编写高质量代码改善java程序的151个建议--[110-117]异常及Web项目中异常处理 原创地址:http://www.cnblogs.com/Alandre/(泥沙砖瓦浆木匠),需要转载的,保 ...

  3. java 151建议_编写高质量代码改善java程序的151个建议——导航开篇

    前言 系列文章: 下个星期度过这几天的奋战,会抓紧java的进阶学习.听过一句话,大哥说过,你一个月前的代码去看下,惨不忍睹是吧.确实,人和代码一样都在成长,都在变好当中.有时候只是实现功能的编程,长 ...

  4. python hello world程序编写_编写高质量代码 改善Python程序的91个建议

    建议1:理解Pythonic概念 建议2:编写Pythonic代码 建议3:理解Python与C语言的不同之处 建议4:在代码中适当添加注释 建议5:通过适当添加空行使代码布局更为优雅.合理 建议6: ...

  5. 编写高质量代码的50条黄金守则

    该文章由本人原创发布,最新版本现已迁移至:编写高质量代码的50条黄金守则 | .Net中文网. 概述 该系列文章由比特飞原创发布,计划用半年时间写完全50篇文章,为大家提供编写高质量代码的一般准则. ...

  6. 编写高质量代码:改善Java程序的151个建议(第1章:JAVA开发中通用的方法和准则___建议1~5)...

                 The reasonable man adapts himself to the world; The unreasonable one persists in trying ...

  7. 编写高质量代码:改善Java程序的151个建议(第9章:多线程和并发___建议125~131)

    建议125:优先选择线程池 建议126:适时选择不同的线程池来实现 建议127:lock与synchronized是不一样的 建议128:预防线程死锁 建议129:适当设置阻塞队列的长度 建议130: ...

  8. 转载----编写高质量代码:改善Java程序的151个建议(第1章:JAVA开发中通用的方法和准则___建议1~5)...

    阅读目录 建议1:不要在常量和变量中出现易混淆的字母 建议2:莫让常量蜕变成变量 建议3:三元操作符的类型务必一致 建议4:避免带有变长参数的方法重载 建议5:别让null值和空值威胁到变长方法    ...

  9. java多线程死锁代码_java多线程死锁 编写高质量代码:改善Java程序的151个建议...

    java多线程死锁 编写高质量代码:改善Java程序的151个建议 第1章 Java开发中的通用方法和准则 建议1:不要在常量和变量中出现易混淆的字母 建议2:莫让常量蜕变成变量 建议3:三元操作符的 ...

最新文章

  1. PTA基础编程题目集-7-3 逆序的三位数
  2. 洛谷 P1136 迎接仪式 解题报告
  3. 大三了,计算机专业学生的困惑。 [转]
  4. 首个月球旅客!SpaceX将送普通人上太空,马斯克暗示首单来自日本
  5. 关于输入法图标消失 只能输入英文 win10 语言选项 键盘那里显示 输入法仅桌面的解决办法
  6. cad查看_CAD查看:Geometric Glovius Pro v5.1.0
  7. 网络防火墙开发二三事 转
  8. 智能陈桥五笔7.8试用编号是多少_学霸的学习方法,听多少都不嫌多
  9. Elastic Sketch: Adaptive and Fast Network-wide Measurements
  10. 免费天气api 真正可用
  11. 读《学会提问》有感(一)
  12. Java精品项目源码第109期精美风在线音乐网站
  13. 数据监控预警系统,实现不同端信息推送
  14. windows环境下利用python进行CGI配置
  15. 计算机高级文秘学什么的,文秘专业主要学什么|文秘专业的职业目标是什么
  16. 【English】主语从句的引导词是如何选择?
  17. 死并不可怕,可怕的是华丽地去死
  18. 计算机上海市大学排名,上海市大学排名一览表2021年最新
  19. 网络数据的背后——网络日志的分析指标
  20. Windows10登录不上Micrsoft账户,解决办法

热门文章

  1. 海康研究院出品:具有场景自适应概念学习的无监督目标检测(附论文下载)...
  2. html5游戏开发-简单老虎机
  3. 虚拟化与hypervisor
  4. The Definitive Guide to Firebase 免积分下载
  5. 界址表、宗地图以图形左上角为起点,顺时针编号很麻烦?本文给你介绍自动批量对图形寻找左上角坐标点,并按顺时针方向进行编号的解决方法,其他任意方位起点及方向编号的原理相同,可以参照本案例修改哦
  6. Mac的录制屏幕和停止录制屏幕
  7. ozf oracle,Oracle EBS 缩写术语,搜集中...
  8. 中国信息安全测评中心:从数据全生命周期看数据泄露防护问题
  9. HTML table表头在左侧,HTML Table锁定表头(CSS实现)
  10. 如何设计一个RPC框架?