try~Catch语句中异常的处理过程
【2014/10/12 21:40】文章待续~
1.函数自身捕获处理异常的情况
以下的样例介绍了try~catch语句中出现异常时语句的运行顺序:
package month10; import java.lang.*; public class TryCatch{ /*
* 函数产生一个ArithmeticException异常
*/
public static void First(){
System.out.println("第一个异常处理的样例");
try{
//double m=5.0/0; 在java中,浮点数double和float能够除0。返回无穷大
int m=5/0;
System.out.println(m+"第一个函数不会继续执行了");
}
catch(ArithmeticException e){
System.out.println("第一个函数捕获了异常");
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} /*
* 函数产生一个OutIndexOfException异常
*/
public static void Second(){
System.out.println("第二个异常处理的样例");
int[] arr=new int[3];
try{
for(int i=0;i<4;i++){
arr[i]=i;
}
}
catch(Exception e){
System.out.println("第二个函数捕获了异常");
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} public static void main(String[] args) { System.out.println("程序执行開始");
First();
Second();
System.out.println("程序执行结束"); } }
运行的结果例如以下:
2. 函数自身不处理异常,抛出异常,直接外层函数处理
try抛出了异常。try语句块中抛出异常之后的语句不会再被运行。
package month10; import java.lang.*; public class TryCatch{ /*
* 函数产生一个ArithmeticException异常
*/
public void First(){
System.out.println("第一个异常处理的样例");
try{
//double m=5.0/0; 在java中,浮点数double和float能够除0,返回无穷大
int m=5/0;
System.out.println(m+"第一个函数不会继续执行了");
}
catch(ArithmeticException e){
//throw用在程序中明白表示这里抛出一个异常。 后面跟一个异常对象(实例).
throw new ArithmeticException("ArithmeticException");
//后面不跟语句
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} /*
* 函数产生一个OutIndexOfException异常
*/
public void Second(){
System.out.println("第二个异常处理的样例");
int[] arr=new int[3];
try{
for(int i=0;i<4;i++){
arr[i]=i;
}
}
catch(ArrayIndexOutOfBoundsException e){
throw new ArithmeticException("ArrayIndexOutOfBoundsException");
}
finally{
//上面的样例这里写的输出语句有错误
System.out.println("第二个异常处理的样例结束");
}
} /*
* 封装了First、Second
*/
public void Thrid(){
System.out.println("函数三将First/Second開始执行");
try{
First();
Second();
}
catch(Exception e){
System.out.println("接受异常"+e.getMessage());
}
System.out.println("函数三之后的语句");
} public static void main(String[] args) { System.out.println("程序执行開始");
TryCatch temp=new TryCatch();
temp.Thrid();
System.out.println("程序执行结束"); } }
函数的运行效果例如以下:
3.函数抛出异常,向上抛,外层函数处理
验证函数执行产生异常,外层函数既没有对异常进行捕获处理、亦没有声明抛出异常、异常信息是否会一直向上抛,直到被处理。
package month10; import java.lang.*; public class TryCatch{ /*
* 函数产生一个ArithmeticException异常
*/
public void First(){
System.out.println("第一个异常处理的样例");
try{
//double m=5.0/0; 在java中,浮点数double和float能够除0,返回无穷大
int m=5/0;
System.out.println(m+"第一个函数不会继续执行了");
}
catch(ArithmeticException e){
//throw用在程序中明白表示这里抛出一个异常。 后面跟一个异常对象(实例).
throw new ArithmeticException("ArithmeticException");
//后面不跟语句
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} /*
* 函数产生一个OutIndexOfException异常
*/
public void Second(){
System.out.println("第二个异常处理的样例");
int[] arr=new int[3];
try{
for(int i=0;i<4;i++){
arr[i]=i;
}
}
catch(ArrayIndexOutOfBoundsException e){
throw new ArithmeticException("ArrayIndexOutOfBoundsException");
}
finally{
//上面的样例这里写的输出语句有错误
System.out.println("第二个异常处理的样例结束");
}
} /*
* 封装了First、Second,
* 函数对First、Second抛出的异常不进行处理
*/
public void Thrid(){ System.out.println("函数三将First/Second開始执行");
First();
Second();
System.out.println("函数三之后的语句");
} /*
* 调用函数Thrid
*/
public void Four(){
try{
Thrid();
}
catch(Exception e){
System.out.println("函数3没有进行异常抛出,可是函数1的异常会一直向上抛,直到被捕获");
}
System.out.println("函数4之后的语句");
} public static void main(String[] args) { System.out.println("程序执行開始");
TryCatch temp=new TryCatch();
temp.Four();
System.out.println("程序执行结束"); } }
执行结果例如以下:
4.验证Checked Exception 是否也符合
上面的样例都验证的是执行时异常。不能全然说明问题。如今,验证Checked Exception。
:函数产生异常,若由函数调用者来捕获处理异常,继续之后的程序代码运行;若产生异常未捕获,异常会沿着调用栈下移,一直找到与之匹配的处理方法,若被处理。从处理的地方開始运行之后的代码;若到达调用栈底仍未找到,程序终止。
加入了CExce()函数,用于生产FileNotFoundException异常。
大家差分吧。
package month10; import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.lang.*; public class TryCatch{ /*
* 函数产生一个ArithmeticException异常
*/
public void First(){
System.out.println("第一个异常处理的样例");
try{
//double m=5.0/0; 在java中,浮点数double和float能够除0。返回无穷大
int m=5/0;
System.out.println(m+"第一个函数不会继续执行了");
}
catch(ArithmeticException e){
//throw用在程序中明白表示这里抛出一个异常。 后面跟一个异常对象(实例).
throw new ArithmeticException("ArithmeticException");
//后面不跟语句
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} /*
* 函数产生一个OutIndexOfException异常
*/
public void Second(){
System.out.println("第二个异常处理的样例");
int[] arr=new int[3];
try{
for(int i=0;i<4;i++){
arr[i]=i;
}
}
catch(ArrayIndexOutOfBoundsException e){
throw new ArithmeticException("ArrayIndexOutOfBoundsException");
}
finally{
//上面的样例这里写的输出语句有错误
System.out.println("第二个异常处理的样例结束");
}
} /*
* 封装了First、Second,
* 函数对First、Second抛出的异常不进行处理
* 加入了CExce()函数
*/
public void Thrid(){ System.out.println("函数三将CExce/First/Second開始执行"); CExce();
First();
Second();
System.out.println("函数三之后的语句");
} /*
* 调用函数Thrid
*/
public void Four(){
try{
Thrid();
}
catch(Exception e){
System.out.println("函数3没有进行异常抛出。此时Checked Exception异常函数Cexce的异常自己捕获处理了异常。此时捕获First的异常");
}
System.out.println("函数4之后的语句");
} /*
*
*/
public void CExce(){
FileInputStream fis=null;
FileOutputStream fos=null;
try{
//目录下没有这个文件,会产生FileNoFoundException。 fis=new FileInputStream("C:\\Users\\acer\\Pictures\\boke\\neojos.jpg");
fos=new FileOutputStream("rt.png");
byte[] b=new byte[1024];
int count=0;
while((count=fis.read(b))!=-1){ //int read(byte[] b)
fos.write(b,0,count); //write(byte[]b,int off,int len)
}
}
catch(IOException e){
System.out.println("IO异常咯");
}
finally{
if(fis!=null){
try{
fis.close();
}
catch(IOException e){
System.out.println("error1");
}
}
if(fos!=null){
try{
fos.close();
}
catch(IOException e){
System.out.println("error2");
}
}
//System.out.println("IO over!");
}
} public static void main(String[] args) { System.out.println("程序执行開始");
TryCatch temp=new TryCatch();
temp.Four();
System.out.println("程序执行结束"); }
}
函数执行截图例如以下:
5.函数体声明抛出异常Throws
函数体声明异常,也就是在方法名后面加上throws ExceptionName,..., 方法本身仅仅是抛出异常,由函数调用者来捕获异常。若产生异常,异常会沿着调用栈下移。一直找到与之匹配的处理方法,若到达调用栈底仍未找到。程序终止。
编写代码,你会发现。
对于Throw unchecked Exception的函数,必须在函数体方法声明时追加throws xxException,否则通只是编译器。
在上面的样例中分别在CExce()和Third函数中追加。
import java.lang.*; public class TryCatch{ /*
* 函数产生一个ArithmeticException异常
*/
public void First(){
System.out.println("第一个异常处理的样例");
try{
//double m=5.0/0; 在java中。浮点数double和float能够除0。返回无穷大
int m=5/0;
System.out.println(m+"第一个函数不会继续执行了");
}
catch(ArithmeticException e){
//throw用在程序中明白表示这里抛出一个异常。 后面跟一个异常对象(实例).
throw new ArithmeticException("ArithmeticException");
//后面不跟语句
}
finally{
System.out.println("第一个异常处理的样例结束");
}
} /*
* 函数产生一个OutIndexOfException异常
*/
public void Second(){
System.out.println("第二个异常处理的样例");
int[] arr=new int[3];
try{
for(int i=0;i<4;i++){
arr[i]=i;
}
}
catch(ArrayIndexOutOfBoundsException e){
throw new ArithmeticException("ArrayIndexOutOfBoundsException");
}
finally{
//上面的样例这里写的输出语句有错误
System.out.println("第二个异常处理的样例结束");
}
} /*
* 封装了First、Second,
* 函数对First、Second抛出的异常不进行处理
* 加入了CExce()函数
*/
public void Thrid() throws IOException{ System.out.println("函数三将CExce/First/Second開始执行"); CExce();
First();
Second();
System.out.println("函数三之后的语句");
} /*
* 调用函数Thrid
*/
public void Four(){
try{
Thrid();
}
catch(Exception e){
System.out.println("函数3没有进行异常抛出,此时Checked Exception异常函数Cexce的异常自己捕获处理了异常。 此时捕获First的异常");
}
System.out.println("函数4之后的语句");
} /*
*
*/
public void CExce() throws FileNotFoundException{
FileInputStream fis=null;
FileOutputStream fos=null;
try{
//目录下没有这个文件,会产生FileNoFoundException。 fis=new FileInputStream("C:\\Users\\acer\\Pictures\\boke\\neojos.jpg");
fos=new FileOutputStream("rt.png");
byte[] b=new byte[1024];
int count=0;
while((count=fis.read(b))!=-1){ //int read(byte[] b)
fos.write(b,0,count); //write(byte[]b,int off,int len)
}
}
catch(IOException e){
throw new FileNotFoundException("文件未找到异常");
}
finally{
if(fis!=null){
try{
fis.close();
}
catch(IOException e){
System.out.println("error1");
}
}
if(fos!=null){
try{
fos.close();
}
catch(IOException e){
System.out.println("error2");
}
}
//System.out.println("IO over!");
}
} public static void main(String[] args) { System.out.println("程序执行開始");
TryCatch temp=new TryCatch();
temp.Four();
System.out.println("程序执行结束"); }
}
函数运行结果例如以下:
这里图片的内容仅仅是用于提示运行的流程,输出文字没有意义
try~Catch语句中异常的处理过程的更多相关文章
- Java异常处理中finally中的return会覆盖catch语句中的return语句
Java异常处理中finally中的return会覆盖catch语句中的return语句和throw语句,所以Java不建议在finally中使用return语句 此外 finally中的throw语 ...
- 在try...catch语句中执行Response.End()后如何停止执行catch语句中的内容
在调用Response.End()时,会执行Thread.CurrentThread.Abort()操作. 如果将Response.End()放在try...catch中,catch会捕捉Thread ...
- C# 中异常抛出捕获机制--throw / try,catch,finally
try { messagebox.show("true"); } catch { messagebox.show("false"); } finally { m ...
- java中异常抛出后代码还会继续执行吗
今天遇到一个问题,在下面的代码中,当抛出运行时异常后,后面的代码还会执行吗,是否需要在异常后面加上return语句呢? public void add(int index, E element){ i ...
- java中异常抛出后代码是否会继续执行
为了回答这个问题,我编写了几段代码测试了一下,结果如下: 代码1:throw new Exception("参数越界"); System.out.println(" ...
- 浅谈java中异常抛出后代码是否会继续执行
问题 今天遇到一个问题,在下面的代码中,当抛出运行时异常后,后面的代码还会执行吗,是否需要在异常后面加上return语句呢? public void add(int index, E element) ...
- 一个问题:关于finally中return吞掉catch块中抛出的异常
今天遇到一个感觉很神奇的问题,记录一下问题以及自己分析问题的思路. 预警:不知道怎么看java字节码的朋友可能需要先看一下如何阅读java字节码才能看懂后面的解释. 我有一段程序: public cl ...
- [JavaScript]catch(ex)语句中的ex
try/catch语句是JavaScript语句提供的异常处理机制,一旦try语句块内部的语句抛出异常,在catch语句块即可捕获到Error类型的异常信息.我们知道JavaScript里是没有块作用 ...
- Sql语法高级应用之六:如何在Sql语句中如何使用TRY...CATCH
TRY...CATCH使用范例 BEGIN TRY //逻辑语句块 END TRYBEGIN CATCH //Catch异常处理块 SET @msg = ERROR_MESSAGE(); PRINT ...
随机推荐
- SuSe Linux 10 企业服务器搭建双机集群配置实例
650) this.width=650;" onclick="window.open("http://blog.51cto.com/viewpic.php?refim ...
- Shiro学习总结(3)——Apache Shiro身份认证
身份验证,即在应用中谁能证明他就是他本人.一般提供如他们的身份ID一些标识信息来表明他就是他本人,如提供身份证,用户名/密码来证明. 在shiro中,用户需要提供principals (身份)和cre ...
- POJ 2253-Frogger (Prim)
题目链接:Frogger 题意:两仅仅青蛙,A和B,A想到B哪里去,可是A得弹跳有限制,所以不能直接到B,可是有其它的石头作为过渡点,能够通过他们到达B,问A到B的全部路径中.它弹跳最大的跨度的最小值 ...
- do_pj--下拉代码脚本的使用
接本目录 /home/zhangshuli/git2/vanzo_team/xulei/Platform.py 在~/bin目录下链接 ln -sf ~/git2/vanzo_team/xulei/P ...
- ios系统和某些移动端background-attachment:fixed不兼容性
固定背景不动:background-attachment:fixed; ios系统和某些移动端background-attachment:fixed不兼容性,没有任何效果,但可以hack一下就可以了, ...
- ES5比较Jquery中的each与map 方法?
1.each es5: var arr = [1, 5, 7, 8, 9];var arr1 = []; arr.forEach(function (v, i) { arr1.push(v * 4) ...
- JavaScript原型及原型链
代码一: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF- ...
- PatentTips - Resource partitioning and direct access utilizing hardware support for virtualization
BACKGROUND The present disclosure relates to the resource management of virtual machine(s) using har ...
- call.apply.冒充对象继承
call方法:让调用对象执行,然后第一参数是谁.调用对象的this就改变,指向谁,后边跟参数,依次对应传入 apply方法:让调用对象执行,然后第一参数是谁.调用对象的this就改变指向是谁,后边跟参 ...
- 最新GitHub账号注册(详细图解)
说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家! 一.简介 GitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名gitHub. ...