【问题背景】

最近在项目上需要用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.

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

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

下面是代码

   private static String getInfo()
{
Throwable stack = new Throwable().fillInStackTrace();//获得栈
StackTraceElement[] trace = stack.getStackTrace();
return " |***ThreadName:"+Thread.currentThread().getName()+" |***MethodName:"+ trace[2].getMethodName() + " |***LineAt:" + trace[2].getLineNumber();//获得想要的信息
}
private static String getTag(){
Throwable stack = new Throwable().fillInStackTrace();
StackTraceElement[] trace = stack.getStackTrace();
return trace[2].getClassName();
}
public static void v(String msg)
{
msg = "|***Message:" + msg;
msg += getInfo();
Timber.tag(getTag());
Timber.v(msg);
}

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

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

【总结】

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

自定义信息丰富的Android Log的更多相关文章

  1. 【朝花夕拾】Android Log篇

    前言  从事Android开发的这些年中,经常碰到这样一个现象:同一款app中,往往有好几种风格迥异的log处理方式,有时候会让维护者晕头转向.同时笔者也经常碰带一些模棱两可的问题:Log等级分好几种 ...

  2. 移动开发首页业界资讯移动应用平台技术专题 输入您要搜索的内容 基于Java Socket的自定义协议,实现Android与服务器的长连接(二)

    在阅读本文前需要对socket以及自定义协议有一个基本的了解,可以先查看上一篇文章<基于Java Socket的自定义协议,实现Android与服务器的长连接(一)>学习相关的基础知识点. ...

  3. Android Log介绍

    android.util.Log常用的方法有以下5个:Log.v() ,Log.d() ,Log.i() ,Log.w() ,Log.e() .按照日志级别从高到低为ERROR, WARN, INFO ...

  4. Android Log图文详解

    android.util.Log常用的方法有以下5个:Log.v() Log.d() Log.i() Log.w() 以及 Log.e() .根据首字母对应VERBOSE,DEBUG,INFO, WA ...

  5. android log机制——输出log【转】

    转自:http://blog.csdn.net/tdstds/article/details/19084327 目录(?)[-] 在android Java code中输出log Logprintln ...

  6. android Log图文详解(Log.v,Log.d,Log.i,Log.w,Log.e)

    在Android群里,经常会有人问我,Android Log是怎么用的,今天我就把从网上以及SDK里东拼西凑过来,让大家先一睹为快,希望对大家入门Android Log有一定的帮助. android. ...

  7. android Log.isLoggable步骤的使用

    原文地址: http://www.cnblogs.com/maxinliang/p/4024442.html android Log.isLoggable方法的使用 android 动态控制logca ...

  8. android log 学习

    一,Bug出现了, 需要“干掉”它 bug一听挺吓人的,但是只要你懂了,android里的bug是很好解决的,因为android里提供了LOG机制,具体的底层代码,以后在来分析,只要你会看bug, a ...

  9. 解读Android LOG机制的实现【转】

    转自:http://www.cnblogs.com/hoys/archive/2011/09/30/2196199.html http://armboard.taobao.com/ Android提供 ...

随机推荐

  1. Sprint第一个冲刺(第八天)

    一.Sprint介绍 完善点餐界面,点击进行跳转. 实验截图: 任务进度: 二.Sprint周期 看板: 燃尽图:

  2. 洛谷P1309 瑞士轮

    传送门 题目大意: 2*n个人,有初始的比赛分数和实力值. 每次比赛前总分从大到小排序,总分相同编号小的排在前面. 每次比赛是1和2比,3和4比,5和6比. 实力值大的获胜得1分. 每次比赛前排序确定 ...

  3. 揭晓UX(用户体验)最大的秘密

    我是佩恩和特勒的粉丝已经多年了.我第一次在现实中看到他们是在上个月,被他们的表演完全迷住了. 我真的很喜欢佩恩和特勒,他们经常“回拉窗帘”,并揭示他们是怎么完成他们的魔法.其他魔术师营造神秘主义和虚假 ...

  4. h5调用手机摄像头/相册

    <!DOCTYPE HTML><html><head> <title>上传图片</title> <meta charset=" ...

  5. 分布式事务之:TCC几个框架的测试情况记录

    国内主要的开源TCC分布式事务框架包括 框架名称 Github地址  star数量  tcc-transaction  https://github.com/changmingxie/tcc-tran ...

  6. 使用CSS3 Flexbox布局

    Flexbox(中文版本可以点击这里)的布局是一个用于页面布局的全新CSS3模块功能.它可以把列表放在同一个方向(从左到右或从上到下排列),并且让这些列表能延伸到占用可用的空间.较为复杂的布局可以通过 ...

  7. 由 MySQL server 和 mysql-connector 版本的不匹配引发的一场惊魂

    剧情还原 今天原计划给领导演示一个小Demo, 昨天在自己机器上调通OK以后就下班了... 今天上午早会后,领导说 “昨天,我让我们IT同事把新的测试环境搭建好了,XXX 你把要演示的Demo部署到上 ...

  8. mongoDB在windows下安装和配置.

    1.首先在官网下载mongoDB的安装包: http://www.mongodb.org/downloads 这里我们下载zip格式的下载,其他的没安装过,不会,就不说了. 2.解压文件后: 3.在D ...

  9. Java复习——多线程与并发库

    开启一个线程 实现一个线程的方式有两种:继承Thread类.实现Runnable接口(也存在说三种的情况,第三种是使用线程并发库中的线程池创建一个线程).这两种方法都需要重写Run方法,具体的线程逻辑 ...

  10. RAC的时间同步问题

    今天在两个节点上面安装RAC,在安装clusterware的时候OUI总是提示失败.查到资料的得知: 特此记录: 需要在在所有的集群节点上设置正确的日期和时间 在安装 Oracle 集群件.数据库以 ...