Java提供的异常体系不可能预见所有错误,可以通过自定义异常来表示程序运行过程中的问题。
建立自定义异常需要从已有异常类继承,可以创造一个构造器,例如
class MyException extends Exception{
public MyException() {}
public MyException(String msg) {super(msg);}
}
public class FullConstructors{
public void f() throws MyException{
System.out.println("Throwing MyException from f()");
throw new MyException();
}
public void main(String[] args) {
try {
f();
}catch(MyException e) {
e.printStackTrace(System.out);
}
}
}
程序运行的结果是:
这里的MyException定义了两个构造器,其中第二个构造器接受一个字符串作为参数,并使用了super关键字调用基类构造器。
printStackTrace()方法打印了从方法调用处到异常抛出处的调用序列,并且输出到标准错误流。直接打印有弊端,可以用logging工具将异常记录到日志中。日志分为七个级别,从高到低为:SEVERE、WARNING、INFO、CONFIG、FINE、FINER、FINEST。可通过logger.setLevel(Level.SEVERE)来设定日志级别,也可以直接用severe()调用与日志级别相关联的方法。
通过Logger。getLogger()方法创建一个String参数的Logger对象,Logger对象会将信息发给System.err:
package myexception;
import java.util.logging.*;
import java.io.*;
public class LoggingException extends Exception{
private static Logger logger = Logger.getLogger("LoggingExceptioni");
public LoggingException() {
StringWriter trace = new StringWriter();
printStackTrace(new PrintWriter(trace));
logger.severe(trace.toString());
}
}
package myexception;
public class Logging {
public static void main(String[] args) {
try {
throw new LoggingException();
}catch(LoggingException e) {
System.err.println("Caught"+e);
}
}
}
输出结果为
这里使用了重载的print Stack()方法,它接受一个java.io.StringWriter对象作为参数,通过调用toString()方法,可以将输出抽取为String。
参考资料:《Java编程思想》