java中的异常
1 定义:
在Java运行过程中出现的错误
2.异常的分类
3. JVM默认处理异常机制
main函数收到这个问题时,有两种处理方式:
a:自己将该问题处理,然后继续运行
b:自己没有针对的处理方式,只有交给调用main的jvm来处理
jvm有一个默认的异常处理机制,就将该异常进行处理.并将该异常的名称,异常的信息.异常出现的位置打印在了控制台上,同时将程序停止运行
4.处理异常的两种方式
(1):try…catch…finally
- try catch
- try catch finally
- try finally
(2):throws
5.try…catch处理多个异常的注意事项
安卓,客户端开发,处理异常一般使用try{…}catch(Exception e){…}
EE,服务端开发,一般都是底层开发,由底层往上抛
- try 后面如果跟多个catch,小的异常放前面,大的异常放后面,根据多态的原理,如果大的异常放前面,就会将所有的子类接受,则后面的小的异常的存在没有意义。
int a = 10 ;
int b = 0;
int[] arr = {11,22,33,44};
try {
// System.out.println(a / b);
// arr = null;
// System.out.println(arr[0]);
System.out.println(arr[10]);
}catch(ArithmeticException ar){
System.out.println("除数为零");//在运行时,处理一个异常后会继续向try以外的代码继续执行
}catch(NullPointerException n){//而try以内的其他代码则无法执行
System.out.println("出现错误");
}catch(Exception e){
System.out.println("出错了");
}
- JDK7新型处理异常的方式
int a = 10 ;
int b = 0;
int[] arr = {11,22,33,44};
try {
System.out.println(a / b);
arr = null;
System.out.println(arr[0]);
}catch(ArithmeticException | NullPointerException m){
System.out.println("出现错误");
}
6.编译期异常和运行时异常的区别
- 所有的RuntimeException类及其子类的实例被称为运行时异常,其他的异常就是编译时异常
(1)编译时异常
Java程序必须显示处理,否则程序就会发生错误,无法通过编译
(在编译整个程序的过程中对可能出现的问题做出处理,例如文件无法找到等问题,这样的异常必须在编译的时候进行处理,否则编译无法通过)
(2)运行时异常
无需显示处理,也可以和编译时异常一样处理
(程序员所犯的错误,需要修改代码,编译时可通过,但运行时出现问题) - 编译时异常和运行时异常的抛出
(1) 编译时异常的抛出(必须对其进行处理,在方法上必须做声明,否则报错)
public static void main(String[] args) throws Exception {
Student s = new Student();
s.setAge(-17);
System.out.println(s.getAge());
class Student {
private String name;
private int age;
.....
public void setAge(int age) throws Exception{
if(age > 0 && age < 150) {
this.age = age;
}
else {
throw new Exception ("年龄不合规范");
}
运行结果:
(2)运行时异常的抛出(可以处理也可以不处理)
public static void main(String[] args) {
Student s = new Student();
s.setAge(-17);
System.out.println(s.getAge());
}
class Student {
private String name;
private int age;
.....
public void setAge(int age) throws RuntimeException{
if(age > 0 && age < 150) {
this.age = age;
}
else {
throw new RuntimeException ("年龄不合规范");
}
}
运行结果与以上相同
7.throw的概述以及和throws的区别
(1)throw:功能方法内部出现某种情况,程序不能继续运行,需要进行跳转时,就用throw把异常对象抛出。
(2)throws和throw的区别
- throws用在方法声明后面,跟的是异常类名
可以跟多个异常类名,用逗号隔开
表示抛出异常,由该方法的调用者来处理 - throw用在方法体内,跟的是异常对象名
只能抛出一个异常对象名
表示抛出异常,由方法体内的语句处理
8.final关键字的概述
(1) finally的特点
被finally控制的语句体一定会执行
特殊情况:在执行到finally之前jvm退出了(比如System.exit(0))
(2):finally的作用
用于释放资源,在IO流操作和数据库操作中会见到
try {
System.out.println(10/0);
} catch (Exception e) {
System.out.println("运算异常");
return;
}finally{
System.out.println("强大");
}
}
运行结果
return在运行时会检测有无finally修饰的语句,在return 语句完全运行完之前会执行此语句,然后彻底返回,但是System.exit(0)直接退出虚拟机,则finally修饰语句不能执行
(3)与finally相关的例题
- final,finally和 finalize的区别
final :修饰的类,不能被继承
修饰的方法,不能被重写
修饰的变量,只能赋值一次
finally:是try语句的语句体,不能单独使用,用来释放资源
finalize:是object类的一个方法,当垃圾回收器确定不存在对该对象的更多引用时,由对象的垃圾回收器调用此方法。 - 如果catch里面有return语句,请问 finally的代码还会执行吗?如果会,请问是在return前还是return后。
return 语句出现时会搭建返回路径,此时变量x 已被装好,在运行finally是改变的a的值仅仅是未装好之前的x值,此代码无意义,一般finally用于释放资源。
运行结果:30
9.自定义异常
(1)自定义异常存在的意义:通过异常的名称准确判断异常的类型
(2)自定义异常
- 继承自Exception(在方法上必须做声明)
- 继承自RuntimeException(方法上可以不做声明)
运行结果(通过合适的提醒找到精确的错误位置)
异常的注意事项及使用情况
- 注意事项
(1)子类重写父类的方法时,子类必须抛出与父类相同的异常或者父类异常的子类。
(2)如果父类抛出多个异常,子类重写父类方法只能抛出相同的异常或者父类异常的子集,子类不能抛出父类没有的异常
(3)如果父类没有异常抛出,子类也不能抛出异常,但是可以使用try - 使用情况:
(1)如果内部可以解决就使用try,处理不了交由调用者调用,用throws
(2)后续程序需要运行用try,不需运行用throws