Practical JAVA (四)异常处理
Practice 16~27
一
异常控制流(exceptional control flow)机制:
try{
<block>
}
catch(<ExceptionClass> e){
<block>
throw e; //若不能处理该异常,则抛出
}
finally{
<block>
}
若在try段抛出异常,先跳过try段内异常后面的语句,执行catch段,再执行finally段,否则,执行完try段,直接处理finally段
若catch段中再次抛出异常,则抛出后依旧执行finally段
如果try里面有return语句被执行,还是会在之后执行finally段。所以在try里使用return要谨慎,最好不要用。
二
处理多个异常,防止被最后一个异常掩盖
一个函数当中,只有最后抛出的异常才会被调用它的函数接收
比如
class Hidden{
public static void main(String args[])
Hidden h = new Hidden();
try{
h.foo();
}
catch (Exception e){
System.out.println("In main, caught exception: " + e.getMessage());
}
public void foo() throws Exception{
try{
throw new Exception("First Exception");
}
catch (Exception e){
throw new Exception("Second Exception");
}
finally{
throw new Exception("Third Exception");
}
}
}
运行结果为:
In main, caught exception: Third Exception
再比如,在读文件的过程中:
class Hidden{
public static void main(String args[]) {
Hidden h = new Hidden();
try {
h.readFile();
}
catch(FileNotFoundException fne){
//
}
catch(IOException ioe){
//
}
}
public void readFile() throw FileNotFoundException, IOException{
BufferedReader br1 = null;
BufferedReader br2 = null;
FileReader fr = null;
try{
fr = new FileReader("data1.fil");
br1 = new BufferedReader(fr);
int i = br1.read();
//
fr = new FileReader("data2.fil");
br2 = new BufferedReader(fr);
i = br2.read();
//
}
finally {
if(br1!=null) br1.close();
if(br2!=null) br2.close();
}
}
}
调用FileReader函数可能产生FileNotFoundException,调用BufferedReader函数,close函数,可能产生IOException
若文件在FileReader的时候产生FileNotFoundException,在close的时候又产生IOException,则真正导致程序出错的原因:文件打不开 会被掩盖
这个时候,要建一个stack来储存这些exception
代码懒得打了,直接截图
三
较复杂的异常处理的原则:
考虑三个问题:异常发生的时候会如何?异常处理后会如何?复入这段代码会如何?
最后一个问题最难回答
可以参考database当中transaction的想法
四
如何处理构造对象时产生的错误
构造对象没有返回值,因此很难判断构造对象是否成功。
避免这种情况的方法有:
方法一
双阶段建构(two-stage construction),将有可能产生错误的代码移出构造函数,组成可以返回错误码的函数
方法二
双阶段建构的另一种形式
使用一个internal flag,代表这个对象建构后的有效性
方法三
在构造函数中抛出异常
异常处理的一种方法是记录异常,一种是将异常写入自己设定的文件,一种是e.printStackTrace(System.err);这个函数提供被抛异常的消息,以及该异常的起源(以stack trace方式呈现),并将它们输出到标准错误串流(standard error stream)。
finally
关于异常处理的一些tips:
1. 在finally里关闭文件,socket等,避免资源泄露
2. 在函数旁边写上 throws <ExceptionClass>,方便调用它的函数进行异常处理
3.不要在循环中使用异常处理
4. 不要用异常处理代替流程控制
5. 不要用异常处理来处理所有的出错
Practical JAVA (四)异常处理的更多相关文章
- Java基础(四)-异常处理机制及其设计
本篇主要是记录自己所理解的Java异常处理机制(基于jdk1.7)以及怎么去处理和设计异常.还记得当初学习Java异常这块的时候都没怎么注意它的用途,以为就是简单的处理下异常,我避免程序出现这样错误就 ...
- 异常处理器详解 Java多线程异常处理机制 多线程中篇(四)
在Thread中有异常处理器相关的方法 在ThreadGroup中也有相关的异常处理方法 示例 未检查异常 对于未检查异常,将会直接宕掉,主线程则继续运行,程序会继续运行 在主线程中能不能捕获呢? 我 ...
- 《practical Java》读书笔记
题记: 花了一周把Peter Haggar的<practical Java>看了遍,有所感悟,年纪大了, 写下笔记,方便日后查看.也希望有缘之人可以看看,做个渺小的指路人. 不足之处还望指 ...
- Java 六种异常处理的陋习(转)
Java 六种异常处理的陋习 原文链接: http://www.cnblogs.com/Android-and-android/archive/2013/05/02/3054469.html 你觉得 ...
- Java开发知识之Java的异常处理
Java开发知识之Java的异常处理 一丶异常概述 在讲解异常之前,我们要搞清楚.什么是异常. 通俗理解就是我们编写的程序出问题了.进行处理的一种手段. 比如我们的QQ.有的时候就崩溃了.比如出现xx ...
- Java 四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor
介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new T ...
- Java的异常处理
Java的异常处理是通过5个关键字来实现的:try,catch,throw,throws,finally.JB的在线帮助中对这几个关键字是这样解释的: Throws: Lists the ...
- Java四种线程池
Java四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor 时间:20 ...
- Java四种引用包括强引用,软引用,弱引用,虚引用。
Java四种引用包括强引用,软引用,弱引用,虚引用. 强引用: 只要引用存在,垃圾回收器永远不会回收Object obj = new Object();//可直接通过obj取得对应的对象 如obj.e ...
- Pascal、VB、C#、Java四种语法对照表
因为工作原因,自学会了vb后陆续接触了其它语言,在工作中经常需要与各家使用不同语言公司的开发人员做程序对接,初期特别需要一个各种语法的对照比,翻看了网络上已有高人做了整理,自己在他基础上也整理了一下, ...
随机推荐
- JAVA手记 JAVA入门(安装+Dos下运行)
JAVA入门特供= =,今天设置环境变量后用dos运行的时候发现出现“找不到或无法加载主类”,索性查了些资料重新看了看JAVA入门的部分. 声明:我的笔记本暂时用的是Win10系统,Windows其他 ...
- Python 开发轻量级爬虫01
Python 开发轻量级爬虫 (imooc总结01--课程目标) 课程目标:掌握开发轻量级爬虫 为什么说是轻量级的呢?因为一个复杂的爬虫需要考虑的问题场景非常多,比如有些网页需要用户登录了以后才能够访 ...
- vps mysql自动关闭
买了个阿里云的vps 装了一个wordpress,mysql一直自动关闭,百思不得其解,只有搜索 最后才发现是因为服务器内存太小,毕竟是最便宜的才512m ---------------------- ...
- codeforces 425B Sereja and Table (枚举、位图)
输入n*m的01矩阵.以及k. n,m<=100,k<=10 问修改至多k个,使得矩阵内的各连通块(连着的0或1构成连通块)都是矩形,且不含另外的数字(边界为0(1)的矩形内不含1(0)) ...
- nyoj123_士兵杀敌(四)_树状数组_插线求点
士兵杀敌(四) 时间限制:2000 ms | 内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ...
- Mac shell 添加VPN 路由
苦于每次使用内网VPN,都需要手动添加route来设置网络的映射,才可以正常使用VPN. 每次都需要自动添加,当然就是觉得很烦,想到Mac的shell.反正每次添加的时候都是在终端执行添加路由.为了方 ...
- WP开发资源
wp开发:连续两次点击返回键退出程序的设计: http://hi.baidu.com/youngytj/item/6be317719cc371306cc37ce4 X http://www.cnblo ...
- 【leetcode】Minimum Window Substring (hard) ★
Given a string S and a string T, find the minimum window in S which will contain all the characters ...
- 【leetcode】Binary Tree Postorder Traversal (hard) ☆
二叉树的后序遍历 用标记右子树vector的方法 vector<int> postorderTraversal(TreeNode *root) { vector<int> an ...
- 【leetcode】Single Number (Medium) ☆
题目: Given an array of integers, every element appears twice except for one. Find that single one. No ...