Java异常
Java异常是Java提供的一种识别及响应错误的一致性机制。
Java异常机制可以使程序中异常处理代码和正常业务代码分离,保证程序代码更加优雅,并提高程序健壮性。在有效使用异常的情况下,异常能清晰的回答3个问题:异常类型回答了“什么”被抛出,异常堆栈跟踪回答了“在哪“抛出,异常信息回答了“为什么“会抛出。
Java异常机制用到的几个关键字:try、catch、finally、throw、throws
• try – 用于监听。将要被监听的代码(可能抛出异常的代码)放在try语句块之内,当try语句块内发生异常时,异常就被抛出。
• catch – 用于捕获异常。catch用来捕获try语句块中发生的异常。
• finally – finally语句块总是会被执行。它主要用于回收在try块里打开的物力资源(如数据库连接、网络连接和磁盘文件)。只有finally块,执行完成之后,才会回来执行try或者catch块中的return或者throw语句,如果finally中使用了return或者throw等终止方法的语句,则就不会跳回执行,直接停止。
• throw – 用于抛出异常。
• throws – 用在方法签名中,用于声明该方法可能抛出的异常。
异常代码如下:
//了解try、catch基本用法以及finally的基本用法
import java.util.InputMismatchException;
import java.util.Scanner;
import org.apache.log4j.Logger;
public class Test {
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
System.out.println("请输入被除数:");
try{
int a=input.nextInt();
System.out.println("请输入除数:");
int b=input.nextInt();
int result=a/b;
}
catch(InputMismatchException ie)
{
//被除数
//ie.printStackTrace();//打印堆栈信息
System.out.println("只能输入数字");
}
catch(ArithmeticException ae)
{
//除数
ae.printStackTrace();//打印堆栈信息
System.out.println(ae.getMessage());//结果:/ by zero
System.out.println("除数不能为0");
}
catch(Exception ex)
{
ex.printStackTrace();//打印堆栈信息
System.out.println("程序异常");
}
finally
{
System.out.println("感谢使用");
}
System.out.println("程序结束");
}
}
//了解throws和throw的基本用法
class MyException extends Exception {
public MyException() {}
public MyException(String msg) {
super(msg);
}
}
public class Demo3 {
public static void main(String[] args) {
try {
test();
} catch (MyException e) {
System.out.println("Catch My Exception");
e.printStackTrace();
}
}
public static void test() throws MyException{
try {
int i = 10/0;
System.out.println("i="+i);
} catch (ArithmeticException e) {
throw new MyException("This is MyException");
}
}
}
结果为:
Catch My Exception
MyException: This is MyException
at Demo3.test(Demo3.java:24)
at Demo3.main(Demo3.java:13)
Java日志
Log4j由三个重要的组件构成:日志信息的优先级(Logger),日志信息的输出目的地(Appender),日志信息的输出格式(Layout)。
日志信息的级别分为四级,优先级从高到低有DEBUG、INFO、WARN、ERROR,用来指定这条日志信息的重要程度;
日志信息的输出目的地指定了日志将打印到控制台还是文件中;
日志信息的输出格式则控制了日志信息的显示内容
注意:Log4j日志级别是定义在org.apache.log4j.Level类中,可以看源码。Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。
A:off 最高等级,用于关闭所有日志记录。
B:fatal 指出每个严重的错误事件将会导致应用程序的退出。
C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。
D:warm 表明会出现潜在的错误情形。
E:info 一般和在粗粒度级别上,强调应用程序的运行全程。
F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。
G:TRACE 一般用于更细粒度级别上,比debug级别更低 H:all 最低等级,用于打开所有日志记录。