`
webdev2014
  • 浏览: 679646 次
文章分类
社区版块
存档分类
最新评论

Android应用中,怎么得到全部异常日志

 
阅读更多

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;
	}


分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics