Java基础学习day15【谷】

Java基础学习day15

在局部内部类的方法中,如果调用局部内部类所声明的方法中的局部变量的话,要求此局部变量声明为final的。
jdk7及之前版本:要求此局部变量显式的声明为final的
jdk8及之后的版本:可以省略final的声明

只能调用不可以修改

异常处理

异常体系结构

java.lang.Thowable

java.lang.Error:一般不编写针对性代码进行处理

java.lang.Exception:可以进行异常的处理

编译时异常

IOException

FileNotFoundException

ClassNotFoundException

运行时异常

NullPointerException 空指针异常

ArrayIndexOutOfBoundException 数组角标过界

ClassCastException 类型转换异常

NumberFormatException 数字转换异常

InputMismatchException 输入不匹配

ArithmeticException 算数异常

过程一:“抛”:

程序在正常执行的过程中,一旦出现异常,就会在异常代码处生成一个异常类的对象。、

并将此对象抛出

一旦抛出对象后,后面的代码将不会再执行

过程二:“抓”

理解为异常的处理方式:

①try–catch–finally

②throws

try–catch–finally的使用

try{
//可能出现异常的代码
}catch(异常类型1变量名1){
//处理异常的方式1
}catch(异常类型2变量名2){
//处理异常的方式2
}catch(异常类型3变量名3){
//处理异常的方式3
}
finally{
//一定会执行的代码
}

说明:

  1. finally是可选的 可以不写,一旦写了不管任何情况都将会执行。
  2. 使用try将可能出现异常代码包装起来,在执行过程中,一旦出现异常,就会生成一个对应异常类的对象,根据此的类型,去catch中进行匹配
  3. 一旦try中的异常对象匹配到某一个catch时,就进入catch中进行异常的处理。一旦处理完成,就跳出当前的try-catcha结构(在没有写finally的情况)。继续执行其后的代码
  4. catch中的异常类型如果没有子父类关系,则谁声明在上,谁声明在下无所谓。
    catch中的异常类型如果满足子父类关系,则要求子类一定声明在父类的上面。否则,报错
  5. 常用的异常对象处理的方式:
    • String getMessage()
    • printstackTrace()
  6. 在try结构中声明的变量,再出了try结构以后,就不能再被调用

体会:使用try-ctch-finally处理编译时异常,是程序在编译时就不再报错,但是运行时仍可能报错。
相当于我们使用try-catch-final1y将一个编译时可能出现的异常,延迟到运行时出现。

​ 开发中,由于运行时异常很常见,所以我们一般就不针对运行时异常进行try-catch-finally了

​ 针对编译时异常,我们说一定要考虑异常的处理。

throws+异常类型

1."throws+异常类型"写在方法的声明处。指明此方法执行时,可能会抛出的异常类型。

一旦当方法体执行时,出现异常,仍会在异常代码处生成一个异常类的对象,此对象满足throws.后异常类型时,就会被抛出。

异常代码后续的代码,就不再执行

体会:try-catch-finally:真正的将异常给处理掉了。
throws的方式只是将异常抛给了方法的调用者。并没有真正将异常处理掉。

3.开发中如何选择使用try-catch-finally还是使用throws?
3.1如果父类中被重写的方法没有throws方式处理异常,则子类重写的方法也不能使用throws,意味着如果子类重写的方法中有异常,必须使用try-catch-finally方式处理。
3.2执行的方法a中,先后又调用了另外的几个方法,这几个方法是递进关系执行的。我们建议这几个方法使用throws的方式进行处理。而执行的方法a可以考虑使用try-catch-final1y方式进行处理。

手动抛出异常(throw)

throw new RuntimeException();

如果是编译时异常,需要用throws进行处理

在调用此方法的类中进行try-catch处理

自定义异常

1.继承于现有结构:RuntimeException Exception

2.提供全局常量:serialVersionUID

3.提供重载的构造器

练习

编写应用程序EcmDef.java,接收命令行的两个参数,要求不能输入负数,计算
两数相除。
对数据类型不一致(NumberFormatException)、缺少命令行参数
(ArrayIndexOutOfBoundsException,
除0(ArithmeticException)及输入负数(EcDef自定义的异常)进行异常处理。
提示:
(1)在主类(EcmDef)中定义异常方法(ecm)完成两数相除功能。
(2)在main0方法中使用异常处理语句进行异常处理。
(3)在程序中,自定义对应输入负数的异常类(EcDef)。
(4)运行时接受参数java EcmDef  20   10//args[0]=“20”args[1]=“10”
(5)Integer类的static方法parseInt(String s)将s转换成对应的int值。
如:int a=Integer.parseInt(“314");//a=314;
public class  EcmDef{
    public static void main(String[] args) {
        try {
            int a = Integer.parseInt(args[0]);
            int b = Integer.parseInt(args[1]);
            System.out.println(ecm(a, b));
        } catch (NumberFormatException e) {
            System.out.println("对数据类型不一致");
        }catch (ArrayIndexOutOfBoundsException e) {
            System.out.println("缺少命令行参数");
        }catch (ArithmeticException e){
            System.out.println("除0");
        }catch (EcDef ecDef){
            System.out.println(ecDef.getMessage());
        }
    }
    public static int ecm(int a,int b) throws EcDef {
        if(a<0||b<0){
            throw new EcDef("输入负数");
        }
        return a/b;
    }

}

自定义异常

三步

1.先继承异常类

2.设置特有序列号(复制父类中的后,稍作修改)

3.创建无参构造器

4.创建有参构造器,括弧里面放msg,调用父类构造器

public class EcDef extends Exception{
    static final long serialVersionUID = -3387516993888888L;
    public EcDef() {
    }
    public EcDef(String msg){
        super(msg);
    }

面试题

throw与throws的区别

throw是手动抛出异常,抛出一个异常对象,生成异常对象的过程,声明在方法体中

throws是处理异常的方式,声明在方法的声明处

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值