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 最低等级,用于打开所有日志记录。