再探java基础——throw与throws

2024-02-23 12:08
文章标签 java 基础 throw throws

本文主要是介绍再探java基础——throw与throws,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以前虽然知道一些异常的处理,也用过一些,但是对throwthrows区别还是有不太清楚。今天用实例测试一下。

异常处理机制

异常处理是对可能出现的异常进行处理,以防止程序遇到异常时被卡死,处于一直等待,或死循环。

异常有两个过程,一个是抛出异常;一个是捕捉异常。

抛出异常

抛出异常有三种形式,一是throw,一个throws,还有一种系统自动抛异常。下面它们之间的异同。

系统自动抛异常

当程序语句出现一些逻辑错误、主义错误或类型转换错误时,系统会自动抛出异常。如:

[java]  view plain copy
  1. public static void main(String[] args) {  
  2.         int a = 5, b =0;  
  3.         System.out.println(5/b);  
  4.         //function();  
  5. }  
系统会自动抛出 ArithmeticException 异常:

Exception in thread "main" java.lang.ArithmeticException: / by zero

at test.ExceptionTest.main(ExceptionTest.java:62)

  再如

[java]  view plain copy
  1. public static void main(String[] args) {  
  2.         String s = "abc";  
  3.         System.out.println(Double.parseDouble(s));  
  4.         //function();  
  5. }  
系统会自动抛出 NumberFormatException 异常:

Exception in thread "main" java.lang.NumberFormatException: For input string: "abc"

at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1224)

at java.lang.Double.parseDouble(Double.java:510)

at test.ExceptionTest.main(ExceptionTest.java:62)


throw

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

一般会用于程序出现某种逻辑时程序员主动抛出某种特定类型的异常。如:

[java]  view plain copy
  1. public static void main(String[] args) {  
  2.         String s = "abc";  
  3.         if(s.equals("abc")) {  
  4.             throw new NumberFormatException();  
  5.         } else {  
  6.             System.out.println(s);  
  7.         }  
  8.         //function();  
  9. }  

会抛出异常:

Exception in thread "main" java.lang.NumberFormatException

at test.ExceptionTest.main(ExceptionTest.java:67)



throws

throws是方法可能抛出异常的声明。(用在声明方法时,表示该方法可能要抛出异常)
语法:[(修饰符)](返回值类型)(方法名)([参数列表])[throws(异常类)]{......}
      如:      public void function() throws Exception{......}

当某个方法可能会抛出某种异常时用于throws 声明可能抛出异常,然后交给上层调用它的方法程序处理。如:

[java]  view plain copy
  1. public static void function() throws NumberFormatException{  
  2.         String s = "abc";  
  3.         System.out.println(Double.parseDouble(s));  
  4.     }  
  5.       
  6.     public static void main(String[] args) {  
  7.         try {  
  8.             function();  
  9.         } catch (NumberFormatException e) {  
  10.             System.err.println("非数据类型不能转换。");  
  11.             //e.printStackTrace();  
  12.         }  
  13. }  
处理结果如下:

非数据类型不能转换。

throw与throws的比较

1、throws出现在方法函数头;而throw出现在函数体。

2throws表示出现异常的一种可能性,并不一定会发生这些异常;throw则是抛出了异常,执行throw则一定抛出了某种异常对象

3、两者都是消极处理异常的方式(这里的消极并不是说这种方式不好),只是抛出或者可能抛出异常,但是不会由函数去处理异常,真正的处理异常由函数的上层调用处理。


好的编程习惯:

1.在写程序时,对可能会出现异常的部分通常要用try{...}catch{...}去捕捉它并对它进行处理;

2.try{...}catch{...}捕捉了异常之后一定要对在catch{...}中对其进行处理,那怕是最简单的一句输出语句,或栈输入e.printStackTrace();

3.如果是捕捉IO输入输出流中的异常,一定要在try{...}catch{...}后加finally{...}把输入输出流关闭;

4.如果在函数体内用throw抛出了某种异常,最好要在函数名中加throws抛异常声明,然后交给调用它的上层函数进行处理。


捕捉异常

先讲捕捉异常

[java]  view plain copy
  1. try{  
  2.  ……  
  3. }catch(Exception e){  
  4.  ……  
  5. }finally{  
  6.  ……  
  7. }  

try{……}中放置可能会发生异常的的语句块,如可能出现异常的函数,也可以是一般的程序语句;catch(){……}用于抓住异常,(Exception e)中Exception是异常的类型,必须是Exception(Exception是所有异常类的父类)的子类。{}定义当出现异常时的处理方法。finally{……}表示不管异常是否发生,都得进行finally{}中的处理。


在捕捉异常的try{...}语句块中,如果出现了异常,则该语句(出现异常的语句)后的程序语句都不执行,而是跳到catch{...}语句块中执行异常的处理。如:

[java]  view plain copy
  1. public static void function1() throws NumberFormatException{  
  2.         System.out.println(Double.parseDouble("abc"));  
  3.         System.out.println("第二条语句。");  
  4.           
  5.     }  
  6.   
  7.     public static void main(String[] args) {  
  8.         try {  
  9.             function1();  
  10.         } catch (Exception e) {  
  11.             System.err.println(e.getMessage());  
  12.             //e.printStackTrace();  
  13.         }  
  14. }  

结果如下,只输出了一条错误提示语:

For input string: "abc"

System.out.println("第二条语句。");未执行。


如果一个函数没有用throws进行抛异常,在调用该函数的方法也同样可以捕捉异常。如

[java]  view plain copy
  1. public static void function() {  
  2.         String s = "abc";  
  3.         System.out.println(Double.parseDouble(s));  
  4.     }  
  5.       
  6.     public static void main(String[] args) {  
  7.         try {  
  8.             function();  
  9.         } catch (Exception e) {  
  10.             System.err.println("非数据类型不能转换。");  
  11.             //e.printStackTrace();  
  12.         }  
  13. }  
处理结果如下:

非数据类型不能转换。


说明:某个函数或某段程序块不管会不会,有没可能抛出异常,都可以加try{...}catch{...}去捕捉它。


自定义异常

用户可以自定义异常,新建一个异常类,让其继承Exception类或Exception的某个子类。然后用throw抛出自己定义的异常类对象。如:

[java]  view plain copy
  1. public static void function() throws ParenthesisMatchingException{  
  2.         String s = "((a+b)";  
  3.         ParenthesisMatchingException e = new ParenthesisMatchingException("括号匹配异常!");  
  4.         if(s.charAt(0)=='(' && s.charAt(1)=='(') {  
  5.             throw e;  
  6.         }  
  7.         System.out.println(s);  
  8.     }  
  9.       
  10.     public static void main(String[] args) {  
  11.         try {  
  12.             function();  
  13.         } catch (Exception e) {  
  14.             System.out.println(e.getMessage());  
  15.             //e.printStackTrace();  
  16.         }  
  17. }  

结果如下 :

括号匹配异常!

这篇关于再探java基础——throw与throws的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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 声明式事物

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智听未来一站式有声阅读平台听书系统小程序源码

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

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]