1、这里讲述的不是在应用中捕获异常信息,然后发到服务器或是写文件。如果想了解那个的话,http://blog.csdn.net/wangduanqing5945/article/details/11093585
2、怎么得到全部的异常信息?
①一种思路:Throwable对象有方法getMessage、getLocalizedMessage等,都是返回的String,但是通过打印看出,这只是一个笼统的错误原因,看到这个错误原因定位不到错误在哪里还是没有用的。
②使用getStackTrace得到堆栈数组StackTraceElement[],最后看了一下,堆栈信息还是不全的,比如,我应用出现空指针了,哪里出现空指针的,通过这些信息还是不好找。
③、其实最容易读懂的错误日志就是,printStackTrace方法打印出来的。然后printStackTrace这个方法还有个重载方法printStackTrace(PrintWriter writer)。所以下面的代码就是用这种方式得到的错误日志:
/**
* 获取错误的信息
*
* @param arg1
* @return
*/
private String getErrorMessage(Throwable arg1) {
PrintWriter pw = null;
Writer writer = null;
try {
writer = new StringWriter();
pw = new PrintWriter(writer);
arg1.printStackTrace(pw);
} catch (Exception e) {
e.printStackTrace();
} finally {
if (null != pw) {
pw.close();
}
}
String error = writer.toString();
return error;
}