Java异常之try,catch,finally,throw,throw

2024-04-04 22:32
文章标签 java 异常 try catch finally throw

本文主要是介绍Java异常之try,catch,finally,throw,throw,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们每天上班,正常情况下可能30分钟就能到达。但是由于车多,人多,道路拥挤,致使我们要花费更多地时间,这就是生活中的异常!

程序和生活一样都会出现异常,先来看个异常:


  
上面出现的是算数错误的异常。

在java中,除去一些编译上的错误(语法)之外,就有异常和错误!

异常的定义是可自己进行处理后,程序依然可以正常运行下去!错误是Java虚拟机抛出的,终止程序的运行,这就是程序和异常的区别。 
 

一:什么是异常处理?

异常处理机制就像我们对平时可能遇到的意外情况,预先想好了一些处理的办法。也就是说,在程序执行代码的时候,万一发生了异常,程序会按照预定的处理办法对异常进行处理,异常处理完毕后,程序继续运行。 
java的异常处理是通过5个关键字来实现的:try、catch、finally、throw、throws。 
 

二:java异常类的层次结构

三.常见的异常类型

Exception                                          异常层次结构的根类 
ArithmeticException                            算数错误情形 
ArrayIndexOutOfBoundsException       数组下标越界 
NullPointerException                           尝试访问null对象成员 
ClassNotFoundException                     不能加载所需的类 
InputMismatchException                     欲得到的数据类型与实际输入的类型不匹配 
IllegalArgumentException                    方法接受到非法参数 
ClassCastException                            对象强制类型转换出错 
NumberFormatException                     数字格式转换异常 
 

四.具体实例

  • try—catch
package Test;import java.util.Scanner;public class Test_Test {public static void main(String[] args) {Scanner input =new Scanner(System.in);System.out.println("请输入被除数:");try {int num1=input.nextInt();System.out.println("请输入除数:");int num2=input.nextInt();System.out.println(String.format("%d / %d = %d",num1, num2, num1 / num2));}catch (Exception e) {System.err.println("出现错误:被除数和除数必须是整数,"+"除数不能为零。");System.out.println(e.getMessage());}
}

运行结果如下:

System.err.println();这种输出方式可以输出错误的消息,在控制台呈现红色。 
System.out用于正常的输出,也就是程序真正想输出的内容。而System.err用于出错信息的输出,也就是你本来不期待看到的东西。

System.out.println(e.getMessage());

这行的作用是——返回该错误的详细信息的字符串。

  • try-catch-finally
package Test;import java.util.Scanner;public class Test_Test {public static void main(String[] args) {Scanner input =new Scanner(System.in);System.out.println("请输入被除数:");try {int num1=input.nextInt();System.out.println("请输入除数:");int num2=input.nextInt();System.out.println(String.format("%d / %d = %d",num1, num2, num1 / num2));}catch (Exception e) {System.err.println("出现错误:被除数和除数必须是整数,"+"除数不能为零。");System.out.println(e.getMessage());}finally{System.out.println("Thanks");}}
}

运行结果如下:

try-catch-finally 程序块的流程大致分为两种情况: 
1. 如果try块中所有语句正常执行完毕,那么finally块就会被执行。 
2. 如果try语句在执行过程中碰到异常,无论这种异常能否被catch块捕获到,都将执行finally块中的代码。

try-catch-finally结构中try块是必须有的,catch和finally块为可选,但两者至少必须出现其中之一。 
  
- try—catch-catch-finally(多重catch块)

package Test;import java.util.InputMismatchException;
import java.util.Scanner;public class Test_Test {public static void main(String[] args) {Scanner input =new Scanner(System.in);System.out.println("请输入被除数:");try {int num1=input.nextInt();System.out.println("请输入除数:");int num2=input.nextInt();System.out.println(String.format("%d / %d = %d",num1, num2, num1 / num2));}catch (InputMismatchException e) {System.err.println("被除数和除数必须是整数。");}catch (ArithmeticException e) {System.err.println("除数不能为零。");}catch (Exception e) {System.err.println("其他未知异常。");System.out.println(e.getMessage());}finally{System.out.println("Thanks");}}
}

运行结果如下:


  
所以,在写异常处理的时候,一定要把异常范围小的放在前面,范围大的放在后面,Exception这个异常的根类一定要刚在最后一个catch里面,如果放在前面或者中间,任何异常都会和Exception匹配的,就会报已捕获到…异常的错误。 
  
下面是try-catch-finally中包含return的情况: 
- 情况一:try{} catch(){}finally{} return;

             
正常按程序顺序执行即可。

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 1;try{x++;System.out.println("我有用!");}catch (Exception e) {System.out.println("我没用!");}finally{++x;System.out.println("我也有用!");}return 2;}
}

运行结果如下:


  
- 情况2:try{ return; }catch(){} finally{} return;

           
程序执行try块中return之前(包括return语句中的表达式运算)代码;         再执行finally块,最后执行try中return;         finally块之后的语句return,因为程序在try中已经return所以不再执行。

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 1;try{x++;System.out.println("我有用!");return 6;}catch (Exception e) {System.out.println("我没用!");}finally{++x;System.out.println("我也有用!");}return 2;}
}

运行结果如下:


  
- 情况3:try{} catch(){return;} finally{} return;

          
程序先执行try,如果遇到异常执行catch块,         有异常:则执行catch中return之前(包括return语句中的表达式运算)代码,再执行finally语句中全部代码,                     最后执行catch块中return. finally之后也就是4处的代码不再执行。         无异常:执行完try再finally再return. 
  
1.有异常的情况:

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{int num=x / 0;System.out.println(num);}catch (ArithmeticException e) {System.err.println("除数不能为0!");return 6;}finally{++x;System.out.println("finally");}return 2;}
}

运行结果如下:

2.无异常的情况:

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{System.out.println("try");}catch (ArithmeticException e) {System.err.println("除数不能为0!");return 6;}finally{++x;System.out.println("finally");}return 2;}
}

运行结果如下:


  
  
- 情况4:try{ return; }catch(){} finally{return;}

          
程序执行try块中return之前(包括return语句中的表达式运算)代码;          再执行finally块,因为finally块中有return所以提前退出。

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{int num = x / 0;System.out.println("try");return 3;}catch (ArithmeticException e) {System.err.println("除数不能为0!");}finally{++x;System.out.println("finally");return 2;}}
}

运行结果如下:


  
- 情况5:try{} catch(){return;}finally{return;}

          
程序执行catch块中return之前(包括return语句中的表达式运算)代码;          再执行finally块,因为finally块中有return所以提前退出。

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{int num = x / 0;System.out.println("try");}catch (ArithmeticException e) {System.err.println("除数不能为0!");return 4;}finally{++x;System.out.println("finally");return 2;}}
}

运行结果如下:


  
情况6:try{ return;}catch(){return;} finally{return;}

          
程序执行try块中return之前(包括return语句中的表达式运算)代码;          有异常:执行catch块中return之前(包括return语句中的表达式运算)代码;                       则再执行finally块,因为finally块中有return所以提前退出。          无异常:则再执行finally块,因为finally块中有return所以提前退出。 
1.有异常

package Test;public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{int num = x / 0;System.out.println("try");return 4;}catch (ArithmeticException e) {System.err.println("除数不能为0!");return 4;}finally{++x;System.out.println("finally");return 2;}}
}

运行结果如下:


  
2.无异常

package Test;
/*** Java学习交流QQ群:589809992 我们一起学Java!*/
public class Test_Test {public static void main(String[] args) {Test1();}public static int Test1(){int x = 5;try{
//            int num = x / 0;
//            System.out.println("try");return 4;}catch (ArithmeticException e) {System.err.println("除数不能为0!");return 4;}finally{++x;System.out.println("finally");return 2;}}
}

运行结果如下:

最终结论: 
任何执行try 或者catch中的return语句之前,都会先执行finally语句,如果finally存在的话。          
如果finally中有return语句,那么程序就return了,所以finally中的return是一定会被return的。                   
编译器把finally中的return实现为一个warning。 
- throw——抛出异常

抛出异常有三种形式,一是throw,一个throws,还有一种系统自动抛异常。 
系统抛出异常:

package Test;public class Test2 {public static void main(String[] args) {int a = 5, b =0;  System.out.println(5/b); }}

运行结果如下:


  
throw抛出异常: 
throw是语句抛出一个异常。语法:throw (异常对象);

package Test;
/*** Java学习交流QQ群:589809992 我们一起学Java!*/
public class Test2 {public static void main(String[] args) {String s = "abc";  if(s.equals("abc")) {  throw new NumberFormatException();} else {  System.out.println(s);  }  }}

运行结果如下:


  
- throws——声明异常

throws是方法可能抛出异常的声明。(用在声明方法时,表示该方法可能要抛出异常)语法:(修饰符)(方法名)([参数列表])[throws(异常类)]{……}

package Test;public class Test2 {public static void main(String[] args) {try {Test3();} catch (NumberFormatException e) {System.err.println("非数据类型不能转换。");}}public static void Test3() throws NumberFormatException{  String s = "abc";  System.out.println(Double.parseDouble(s));  }  
}

运行结果如下:

如果在一个方法体中抛出了异常,那么我们就可以通过throws——声明异常来通知调用者,非常方便。 
  
throws表示出现异常的一种可能性,并不一定会发生这些异常;throw则是抛出了异常,执行throw则一定抛出了某种异常对象。 
  
最后说一句,try-catch-finally虽好用,但是如果是滥用,这样只是会让程序的可读性变的很糟糕,当程序报错,就无法快速准确的定位了,物尽其用 人尽其才嘛!

这篇关于Java异常之try,catch,finally,throw,throw的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/876966

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听