异常
try {}catch(){}关键字
异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。
三种类型的异常:
- 检查性异常:最具代表的检查性异常是用户错误或问题引起的异常,这是程序员无法预见的。例如要打开一个不存在文件时,一个异常就发生了,这些异常在编译时不能被简单地忽略。
- 运行时异常: 运行时异常是可能被程序员避免的异常。与检查性异常相反,运行时异常可以在编译时被忽略。
- 错误ERROR: 错误不是异常,错误是灾难性的致命错误,是程序无法控制和处理的,是脱离程序员控制的问题。错误在代码中通常被忽略。例如,当栈溢出时,一个错误就发生了,它们在编译也检查不到的。
异常发生的原因有很多,通常包含以下几大类:
- 用户输入了非法数据。
- 要打开的文件不存在。
- 网络通信时连接中断,或者JVM内存溢出。
- 非法参数
java把异常当作对象来处理,并定义一个基类java.lang.Throwable作为异常的超类,所有的异常类是从 java.lang.Exception 类继承的子类。
在java API中已经定义了许多异常类,这些异常类分为两类,错误Error和异常Exception。
捕获异常
使用 try 和 catch 关键字可以捕获异常。try/catch 代码块放在异常可能发生的地方。
try/catch代码块中的代码称为保护代码,使用 try/catch 的语法如下:
try{
// 程序代码
}catch(ExceptionName e1){//ExceptionName为异常名
//Catch 块
}catch(ExceptionName e2){
//Catch块
}finally{
//善后工作
}
【注】假设要捕获多个异常,需把最大的异常放在最后面,否则报错
Catch 语句包含要捕获异常类型的声明。当保护代码块中发生一个异常时,try 后面的 catch 块就会被检查。
如果发生的异常包含在 catch 块中,异常会被传递到该 catch 块,这和传递一个参数到方法是一样。
//为捕捉异常时
//需求:数字一个数字输出该数字
import java.util.Scanner;
public class Demo01 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("请输入一个数字:");
int i = sc.nextInt();
System.out.println("该数字为:"+i);
}
}
正常输入:
请输入一个数字:12
该数字为:12
当输入其他非数字时:
请输入一个数字:java
Exception in thread “main” java.util.InputMismatchException
at java.base/java.util.Scanner.throwFor(Scanner.java:939)
at java.base/java.util.Scanner.next(Scanner.java:1594)
at java.base/java.util.Scanner.nextInt(Scanner.java:2258)
at java.base/java.util.Scanner.nextInt(Scanner.java:2212)
test/test.Demo01.main(Demo01.java:9)
//捕捉异常
import java.util.Scanner;
public class Demo01 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("请输入一个数字:");
try {//捕捉输入时的异常
int i = sc.nextInt();
System.out.println("该数字为:"+i);
}catch(Exception e){
System.out.println("输入异常!");
}
}
}
正常输入:
请输入一个数字:12
该数字为:12
当输入其他非数字时:
请输入一个数字:java
输入异常!
CTRL + ALT + T:可以在IDEA自动区分代码,并将其包裹起来
throws/throw 关键字:
如果一个方法没有捕获到一个检查性异常,且这个方法无法处理该异常,那么该方法必须使用 throws 关键字来声明。throws 关键字放在方法签名的尾部。
也可以使用 throw 关键字抛出一个异常,无论它是新实例化的还是刚捕获到的。
语法格式如下:
修饰词 返回值类型 方法名(参数列表) throws 抛出异常类型{
}
如:
public void Name() throws Exception{
}
下面方法的声明抛出一个 RemoteException 异常:
import java.io.*;
public class className
{
public void deposit(double amount) throws RemoteException
{
// Method implementation
throw new RemoteException();
}
//Remainder of class definition
}
一个方法可以声明抛出多个异常,多个异常之间用逗号隔开。
例如,下面的方法声明抛出 RemoteException 和 InsufficientFundsException:
import java.io.*;
public class className
{
public void withdraw(double amount) throws RemoteException,
InsufficientFundsException
{
// Method implementation
}
//Remainder of class definition
}
注意下面事项:
- catch 不能独立于 try 存在。
- 在 try/catch 后面添加 finally 块并非强制性要求的。
- try 代码后不能既没 catch 块也没 finally 块。
- try, catch, finally 块之间不能添加任何代码。
自定义异常
在 Java 中你可以自定义异常。编写自己的异常类时需要记住下面的几点。
- 所有异常都必须是 Throwable 的子类。
- 如果希望写一个检查性异常类,则需要继承 Exception 类。
- 如果你想写一个运行时异常类,那么需要继承 RuntimeException 类。
class MyException extends Exception{
}