## 概述
是java代码编译或者运行过程中出现的问题.
## 异常的继承体系
1. Exception(普通问题):平时指的异常是这个.平时开发只研究异常,不研究错误.
2. Error(严重的问题):比如语法错误,如果程序出现了错误,只能改代码.
3. 共同的父类Throwable
## 异常分类
1. 编译时异常:指的是Exception以及Exception子类(RuntimeException除外).
2. 运行时异常:指的是RuntimeException以及RuntimeException的子类.
## 异常基本操作
1. 创建异常对象(JDK已自定义异常会自动创建对象,自定义异常需要手动创建)
2. 抛出异常(不处理异常,不处理也是一种处理),JVM报错.
3. 捕获异常(处理异常).
## 注意
异常处理,指处理的一种可能性,即有了异常处理的代码,不一定会产生异常.如果没有产生异常,则代码正常执行,如果产生了异常,则终端当前执行代码,执行异常处理代码.
1.运行时异常被抛出可以不处理,即不捕获也不声明抛出.
如果父类方法抛出了多个异常,子类重写父类方法时,只能抛出相同的异常或者该异常的子类异常.
2. 父类方法没有抛出异常,子类异常重写父类方法时也不可抛出异常.此时子类产生该异常,只能捕获处理,不能声明抛出(多线程会用到这个)
3. 当多异常处理时,捕获处理,前边的类不能是后面类的父类.
4. 在try/catch之后可以追加finally代码块,其中的代码一定会被执行,通常用于资源回收.
## 异常产生的过程
默认的方式叫中断处理方式. throw new 是虚拟机自动new的对象,它会根据异常的类型来new对象,thorw的目的是看看有没有程序来处理异常,如果没有程序处理异常,那么程序会中断执行.
![](https://box.kancloud.cn/1a1c2c77f000c8991aa36a04756042f8_1201x431.png)
## 模拟虚拟机产生异常
~~~
public class ExceptionDome
{
public static void main(String[] args)
{
int[] nums = {1, 2};
System.out.println(getNum(nums));
System.out.println("hello"); //这里执行不了
}
public static int getNum(int[] nums)
{
if (nums.length <= 2)
throw new ArrayIndexOutOfBoundsException("索引越界"); //只要执行到了throw异常肯定抛出了
return nums[2];
}
}
~~~
![](https://box.kancloud.cn/a1cc3239f34e2537560ccb556fcbf9e5_1448x254.png)
## 异常处理的第一种方式(不处理,或者叫再次申明操作)
使用throws(形容词),形容可能抛出的异常名称.处理异常是处理的一种可能性. throws表示某一个方法可能抛出XX异常,要求调用者去处理它. 也可以叫做
### 格式
~~~
public static int getNum(int[] nums) throws ArrayIndexOutOfBoundsException , XXException
{
}
~~~
## 异常处理的第二种方式(捕获处理)
### 格式
~~~
try{
//可能出现异常的代码
}catch (Exception e){
//处理异常
}finally{
//必须要执行代码,比如释放资源的代码
}
~~~
## 其他的处理方式一 (多个异常分别处理)
看起来很清晰,但是很少用,增加了代码量.
~~~
FileReader fr = null;
try {
fr = new FileReader("1.xxx");
} catch (IOException e) {
System.out.println("打开文件失败");
}
try {
int ch = fr.read();
} catch (IOException e) {
System.out.println("读取文件失败");
}
try {
fr.close();
} catch (IOException e) {
System.out.println("关闭文件失败");
}
~~~
## 其他的处理方式二 (多个异常一次捕获,多次处理)
这种方式也不常用. 要注意catch异常类型的顺序.下面两个异常类型就不能颠倒顺序,否则报错,多个异常如果有子父类关系,必须把子类异常写在前面.
~~~
FileReader fr = null;
try {
fr = new FileReader("1.xxx");
int ch = fr.read();
fr.close();
} catch (FileNotFoundException file) {
System.out.println("关闭文件失败");
} catch (IOException io) {
System.out.println("文件读取或者关闭失败");
}
~~~
## 其他的处理方式三 (多个异常一次捕获,一次处理)
最常用,一个try,一个catch.
~~~
FileReader fr = null;
try {
fr = new FileReader("1.xxx");
int ch = fr.read();
} catch (IOException io) {
System.out.println("文件读取或者关闭失败");
} finally {
try {
fr.close();
} catch (IOException e) {
System.out.println("文件关闭失败");
}
}
~~~
## 运行时异常
如何区分一个异常到底是编译时一场还是运行时异常.
1. 编译时异常:在编译的时候会报错的(需要我们去处理)
2. 运行时异常:在编译的时候不会报错.只要定义一个方法,在方法中抛出一个异常对象,如果编译报错那么就是编译时异常,如果编译成功,那么就是运行时异常.
## 自定义异常
1. 类名必须要以Exception结尾.
2. 必须继承Exception或RuntimeException.
3. 至少有两个构造,一个是空参的,一个是客接收String类型的.
~~~
public class PersonException extends Exception
{
public PersonException()
{
super();
}
public PersonException(String s)
{
super(s);
}
}
~~~
## 实例
~~~
public class NoSuchAgeException extends Exception
{
public NoSuchAgeException()
{
super();
}
public NoSuchAgeException(String s)
{
super(s);
}
}
~~~
~~~
public class Person
{
private String name;
private int age;
public Person(int age) throws NoSuchAgeException
{
if (age < 0 || age > 150)
throw new NoSuchAgeException("年龄非法");
this.age = age;
}
}
~~~
~~~
public class main
{
public static void main(String[] args)
{
try {
Person p = new Person(200);
} catch (NoSuchAgeException e) {
e.printStackTrace();
}
System.out.println("hello"); //自定义的异常程序会继续执行
}
}
~~~
- 环境
- Java基础
- 数据类型
- 基本类型
- 引用类型
- Array
- Class
- ArrayList
- 流程控制
- ASCII码表
- 面向对象
- 概述
- 变量
- this
- 修饰符
- 封装
- 继承
- final
- static
- 接口
- 接口
- 抽象类
- overload
- 接口和抽象类区别
- 案例
- 多态
- 构造方法
- super
- 匿名对象
- 内部类
- 静态导入
- 包的声明和访问
- 代码块
- 代理设计模式
- 静态代码块
- Object类
- lambda表达式
- 枚举
- 定义枚举
- 常用方法
- 枚举常量
- 异常
- 可变参数
- Properties
- 概述
- Properties和持久化有关的方法
- 反射
- 类加载器
- 概述
- Class类
- 获取构造方法并运行
- 获取成员变量并改值
- 获取成员方法并运行
- 反射泛型擦除
- 反射通过配置文件运行
- 常用 API
- Date类
- DateFormat类
- Calendar类
- Math类
- String类
- object类
- System类
- 正则表达式
- BigInteger类
- BigDecimal类
- Arrays工具类
- StringBuffer类
- 基本类型包装类
- 自动装箱和自动拆箱
- 框架集合
- collection接口
- 概述
- 接口方法
- 迭代器
- 迭代器并发异常
- 增强for循环
- 泛型
- hashCode和equals
- List接口
- 概述
- ArrayList
- LinkedList
- vector
- Set接口
- 概述
- 对象的哈希值
- HashSet
- LinkedHashSet
- 保证自定义元素的唯一性(重写)
- ArrayList和HashSet的contains原理
- Map接口
- 概述
- Map集合常用方法
- 迭代Map
- Map存储自定义类型
- HashMap
- LinkedHashMap
- Hashtable
- 嵌套Map遍历
- 方法的可变参数
- collections工具类
- 集合嵌套
- 集合特点总结
- Collection集合工具类
- Arrays工具类
- File类
- 概述
- 获取方法
- 创建和删除
- 判断方法
- 其他方法
- 文件过滤器
- IO流
- 字节流
- 概述
- 字节流
- 字节流复制文件
- 字节缓冲流
- 复制单级文件夹
- 使用字节流读取中文的乱码问题
- 字符编码表
- 方便程序员的IO流
- 转换流
- 概述
- OutputStreamWriter类
- InputStreamWriter类
- 转换流和其他子类的区别
- 序列化流
- 概述
- 序列化接口以及版本号问题
- transient
- 打印流
- 多线程
- 概述
- main线程介绍
- 开启线程方式一:Thread类
- 开启线程方式二:Runnable类
- 线程的执行原理
- 使用哪种方式好
- 使用匿名内部类创建线程
- 线程安全
- ThreadLocal
- 网络编程
- XML
- 概述
- 语法
- 元素标签
- 属性
- 转义字符
- CDATA区
- XML约束
- DTD约束
- 三种引入DTD的方式
- DTD语法
- Schema约束
- JDBC
- 概述
- JDBC原理
- JDBC查询操作
- JDBCUtils
- 预处理对象
- JDBC连接池
- 概述
- DBCP
- C3P0
- DBUtils操作
- ArrayHandler
- ArrayListHandler
- BeanHandler
- BeanListHandler
- ColumnListHandler
- MapHandler
- MapListHandler
- ScalarHandler
- 事务
- 事务概述
- 原生JDBC完成转账
- DBUtils完成转账
- 事务特性
- 三层思想
- 概述
- JavaWEB
- tomcat
- servlet
- 概述
- 映射servlet
- Servlet接口
- HttpServlet类
- load-on-startup
- servletContext
- ServletRequest
- ServletResponse
- Cooike&Session
- servlet三大域对象
- JSP
- 概述
- jsp内置对象
- 指令
- page
- include
- taglib
- JSP中的四个域对象
- jsp的一个动作标签
- EL表达式
- 概述
- 获取域中数据
- 执行运算
- el表达式中的内置对象
- jsti标签
- 概念
- jstl分类
- Filter过滤器
- 概述
- 生命周期
- url-pattern配置
- filter的chain过滤链
- filter-mapping子标签
- 全局统一错误页面
- filterConfig
- 自动登录实例
- 全局统一编码
- Listener监听器
- 概念
- 监听器分类
- 监听三个对象的创建和销毁
- 监听三个对象属性的变化
- 监听javabean在session中的状态变化
- 定时器
- 概念
- calendar日历
- 邮件
- 概述
- JSON
- 数据结构
- 堆栈结构
- 队列结构
- 数组结构
- 链表结构
- 基础加强
- 面试题:增强一个对象的方法有几种方式?
- 装饰者增强
- 动态代理
- 动态代理
- 动态代理细节
- 使用动态代理解决字符集编码
- 注解
- 概述
- 扩展的自定义注解
- 类加载器
- 全盘负责托管机制
- 开发模式
- 问题
- lambda
- 函数式编程思想概述
- String字符串