自定义信息丰富的Android Log

【问题背景】

 

最近在项目上需要用LOG来查看和定位一些信息,但是系统原生的LOG实在太乱,信息也不太多,比如调用行数,所在方法,所在类名,线程名称都没有。

 

【初步想法】

 

本着开源的精神,首先去GitHub上面搜寻了一番,果然发现了不少优秀的项目,经过对比,选定了,Logger和Timber

 

【遇到的问题】

 

毫无疑问,Logger和Timber都是非常优秀的项目,但是我们在使用过程中还是遇到了一些问题。

1.Logger在进行日志搜索的时候只会显示搜索行,其他信息丢失了

 

举个例子,下面是Logger的正常输出,但是当我们搜索关键字test3的时候,就只会显示一行||test3,其他可爱的信息就丢失掉了

2.Timber的其他信息过少。

【解决】

 

既然都不符合我们的要求,那么我们就自己写吧,首先观察Logger是如何做到打印方法名和行数等信息的

 

通过查看源码,我们发现看似复杂的流程其实一点都不复杂,JAVA的设计者们早就为我们准备好了相关的类和信息。

 

最关键的代码就是这一行

StackTraceElement[] trace = Thread.currentThread().getStackTrace();

那么,这个getStackTrace里面发生了什么?返回的StackTraceElement里面又包含了什么信息呢?

 

通过查找官方的文档,我们找到了这么一句,Provides programmatic access to the stack trace information printed by printStackTrace();

翻译过来就是,提供程序性的对printStackTrace()所打印信息的访问。

 

printStackTrace()看起来是不是有点眼熟,对了,就是在我们处理异常的时候在catch里面的最常用处理方式,e.printStackTrace();

 

这个函数会打印出异常的详细信息,例如线程,方法名,行数等等,这些信息正是我们需要的!

 

那么返回的StackTraceElement数组里面又是装的什么东西呢?

官方文档也给了我们答案

An element in a stack trace, as returned by Throwable.getStackTrace(). Each element represents a single stack frame. All stack frames except for the one at the top of the stack represent a method invocation. The frame at the top of the stack represents the execution point at which the stack trace was generated. Typically, this is the point at which the throwable corresponding to the stack trace was created.

 

简单的说里面每个元素都代表了一个栈帧。

 

有了以上的信息,我们就可以开始动手了。

 

下面是代码

 1   private static String getInfo()
 2     {
 3             Throwable stack = new Throwable().fillInStackTrace();//获得栈
 4             StackTraceElement[] trace = stack.getStackTrace();
 5             return  " |***ThreadName:"+Thread.currentThread().getName()+"  |***MethodName:"+ trace[2].getMethodName() + "  |***LineAt:" + trace[2].getLineNumber();//获得想要的信息
 6     }
 7     private  static String getTag(){
 8             Throwable stack = new Throwable().fillInStackTrace();
 9             StackTraceElement[] trace = stack.getStackTrace();
10             return  trace[2].getClassName();
11         }
12     public static  void v(String msg)
13     {
14         msg = "|***Message:" + msg;
15         msg += getInfo();
16         Timber.tag(getTag());
17         Timber.v(msg);
18     }

 

有了代码,让我们看看最终的效果

可以看到,我们所需要的信息都被打印出来了,而且在同一行,虽然简答,但是却非常的实用,这样在我们搜索的时候,就可以看到更多的信息啦。

 

【总结】

JAVA其实所包含的内容非常多,我平时对JAVA的了解还稍显浅薄,很多看似神奇的开源项目就其本身的实现来说是比较简单的,不能光会用,而且要根据自己的需求来进行合理的改造,虚心学习,勤于总结。

 

posted @ 2015-12-02 15:01  u3  阅读(1211)  评论(2编辑  收藏  举报