1.学习异常的原因?
如果没有异常处理机制,那么程序的一点小问题,都会导致【程序终止运行】。实际开发中显然是不可能的,所以异常对于程序来说是非常重要的。
2.处理异常的方式:
A.if结构:
1。代码量大,代码结构不明显
2。程序员的大部分精力不是用在流程上,而是“堵漏洞”。
3。遗留一个漏洞,程序依然终止。
B。异常处理机制:
try catch finally throw throws
异常的捕获 抛出异常 声明异常。
3.异常处理的结构:
第一种: try---catch:
程序正常运行:只走try代码块里的代码;catch块不执行。
程序发生异常:走try报错前的代码--会产生一个异常对象;
异常对象与catch块捕获的异常类型进行对比;
如果匹配:执行对应catch块代码;
如果不匹配:程序依然终止。
第二种:try--catch---catch:
程序正常运行:只走try代码块里的代码;catch块不执行。
程序发生异常:走try报错前的代码--会产生一个异常对象;
异常对象与catch块捕获的异常类型进行对比;
如果匹配:执行对应catch块代码;【只有一个匹配的catch块代码】
如果不匹配:程序依然终止。
注意:1.父类的异常类型【必须】在最后一个catch里。
2.子类的异常类型顺序无关。
3.最后一个catch块都是存放父类的异常类型。
第三种:try--catch--catch--finally
程序正常运行:只走try代码块里的代码;catch块不执行;走finally。
程序发生异常:走try报错前的代码--》会产生一个异常对象;
异常对象与catch块捕获的异常类型进行对比;
如果匹配:执行对应catch块代码;【只有一个匹配的catch块代码】
---走finally
如果不匹配:程序依然终止。 ---走finally
【问题:什么情况下,finally不走】
1.return :finally代码块依然执行;
先执行catch块中return前面的代码;
再执行finally块中的代码;
最后执行return。
2.System.exit(1);程序退出。 终止finally块的执行。
4.输出异常信息的形式:
System.out.println("提示信息");
System.out.println(e.getMessage());
e.printStackTrace();
5.throws关键字(声明异常):
---作用:我处理不了,你来处理,我告诉你应该注意的事项。
当你需要告诉调用者,该方法需要注意异常时,使用throws。
使用:
1.在方法定义的时候:
public void 方法名1() throws 异常类型1,异常类型2{
}
2.方法调用的时候:两种方法来处理:
A。使用try--catch进行异常捕获
try {
被调用的方法名1();
} catch (异常类型1 e) {
e.printStackTrace();
} catch (异常类型2 e) {
e.printStackTrace();
}finally{
}
B。不处理,继续往上声明异常:
public void 方法名2()throws 异常类型1,异常类型2{
被调用的方法名1();
}
6.throw(抛出异常):
---不是异常,为了引起调用者重视,手动抛出异常。
使用throw:
public void setsex(String str){
if(!str.equals("男")){
throw new ClassCastException("性别必须为男或者女");
}else{
String sex=str;
}
}
7.异常分类:
object
throwable
error Exception
checked(编译异常) Running(运行异常)
error :仅靠程序本身无法恢复的严重错误。
Exception:→由java应用程序抛出和处理的非严重错误。
checked:异常必须处理。(不处理,无法运行)
Running:不处理可以,一旦发生异常,程序终止。
8.log4j 开源日志文件:
作用:把异常信息,在一个独立的文件里进行记录或者是输出到控制台。
步骤:
1.把log4j-1.2.17.jar 方法项目的lib文件夹下;加载:选中--右键---buil path---add to buil path
2.把log4j.properties 放到项目src ,不能放到src外面,或者是src的子目录都不行。
3.调用:
创建logger对象:
public static Logger logger=Logger.getLogger(Test.class);
在catch块中写记录异常语句:
logger.debug("提示信息");
logger.debug(e.getMessage());
|
这里可以是debug,info,warm,error,fatal五个输出级别
4.刷新项目,出现 jbit.log文件,记录异常信息