android上一个可追踪代码具体到函数某行的日志类

 更新时间:2012年12月25日 10:51:08   作者:  
追踪代码到函数具体某行,这样的功能,是每一个程序员都希望会有的,因为它可以帮助我们追踪到某行代码的错误,接下来介绍下android上一个可追踪代码到函数具体某行的日志类,希望对开发者有所帮助
代码如下:
复制代码 代码如下:

package xiaogang.enif.utils;

/**
* The Class LogUtils for log printing, which help us
* easy to trace our codes or logics in the project .
*
* @author zhao xiaogang
* @time 2011.4.12
*/
public class LogUtils {

private final static int VERBOSE = 0;
private final static int DEBUG = 1;
private final static int INFO = 2;
private final static int WARN = 3;
private final static int ERROR = 4;
private final static int DEFAULT_LEVEL = -1;

private int level;

private final String clazz;

private static final String TAG = "LogUtils";

public static LogUtils getDebugLog(Class<?> clazz, int l) {
LogUtils log = new LogUtils(clazz);
log.level = l;
return log;
}

public static LogUtils getLog(Class<?> clazz) {
return new LogUtils(clazz);
}

public LogUtils(Class<?> clazz) {
this.clazz = "[" + clazz.getSimpleName() + "] ";
level = DEFAULT_LEVEL;
}

public void verbose(String message) {
verbose(message, null);
}

public void debug(String message) {
debug(message, null);
}

public void info(String message) {
info(message, null);
}

public void warn(String message) {
warn(message, null);
}

public void error(String message) {
error(message, null);
}

public void verbose(String message, Throwable t) {
if (VERBOSE < level)
return;
if (message != null)
android.util.Log.v(TAG, clazz + " Line: " + getLineNumber() + " : " + message);
if (t != null)
android.util.Log.v(TAG, clazz + " Line: " + getLineNumber() + " : " + t.toString());
}

public void debug(String message, Throwable t) {
if (DEBUG < level)
return;
if (message != null)
android.util.Log.d(clazz, clazz + " Line: " + getLineNumber() + " : " + message);
if (t != null)
android.util.Log.d(clazz, clazz + " Line: " + getLineNumber() + " : " + t.toString());
}

public void info(String message, Throwable t) {
if (INFO < level)
return;
if (message != null)
android.util.Log.i(TAG, clazz + " Line: " + getLineNumber() + " : " + message);
if (t != null)
android.util.Log.i(TAG, clazz + " Line: " + getLineNumber() + " : " + t.toString());
}

public void warn(String message, Throwable t) {
if (WARN < level)
return;
if (message != null)
android.util.Log.w(TAG, clazz + " Line: " + getLineNumber() + " : " + message);
if (t != null)
android.util.Log.w(TAG, clazz + " Line: " + getLineNumber() + " : " + t.toString());
}

public void error(String message, Throwable t) {
if (ERROR < level)
return;
if (message != null)
android.util.Log.e(TAG, clazz + " Line: " + getLineNumber() + " : " + message);
if (t != null)
android.util.Log.e(TAG, clazz + " Line: " + getLineNumber() + " : " + t.toString());
}

private static int getLineNumber() {
return Thread.currentThread().getStackTrace()[5].getLineNumber();
}
}

好用的话,记得给好评,嘿嘿!

相关文章

  • Flutter绘图组件之CustomPaint使用详解

    Flutter绘图组件之CustomPaint使用详解

    CustomPaint是Flutter中用于自由绘制的一个widget,它与android原生的绘制规则基本一致,以当前Canves(画布)的左上角为原点进行绘制。本文将详细讲解CustomPaint的使用教程,需要的可以参考一下
    2022-03-03
  • android短信管理器SmsManager实例详解

    android短信管理器SmsManager实例详解

    这篇文章主要为大家详细介绍了android短信管理器SmsManager实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Android Activity之间相互调用与传递参数的原理与用法分析

    Android Activity之间相互调用与传递参数的原理与用法分析

    这篇文章主要介绍了Android Activity之间相互调用与传递参数的原理与用法,较为详细的分析了Android组件的构成以及Activity的创建、调用、切换等相关操作技巧,需要的朋友可以参考下
    2016-08-08
  • Android手机卫士之确认密码对话框

    Android手机卫士之确认密码对话框

    这篇文章主要为大家详细介绍了Android手机卫士之确认密码对话框,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Android使用Scrolling机制实现Tab吸顶效果

    Android使用Scrolling机制实现Tab吸顶效果

    app 首页中经常要实现首页头卡共享,tab 吸顶,内容区通过 ViewPager 切换的需求,以前往往是利用事件处理来完成,但是这些也有一定的弊端和滑动方面不如意的地方,本文我们利用NestedScrolling机制来实现,感兴趣的朋友可以参考下
    2024-01-01
  • Android实现自定义手势和识别手势的功能

    Android实现自定义手势和识别手势的功能

    这篇文章主要介绍了Android实现自定义手势和识别手势的功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • Android Gradle Build Error:Some file crunching failed, see logs for details的快速解决方法

    Android Gradle Build Error:Some file crunching failed, see l

    这篇文章主要介绍了Android Gradle Build Error:Some file crunching failed, see logs for details的快速解决方法的相关资料,需要的朋友可以参考下
    2016-10-10
  • Android开发之EditText框输入清理工具类示例

    Android开发之EditText框输入清理工具类示例

    这篇文章主要介绍了Android开发之EditText框输入清理工具类,涉及Android事件监听及输入框清理相关操作技巧,需要的朋友可以参考下
    2018-01-01
  • Android 多个Activity之间的传值

    Android 多个Activity之间的传值

    本篇文章将用一个实例,详细的为大家讲解怎么注册并激活一个新的Activity,以及多个Activity之间如何传值
    2013-11-11
  • Android定时开机的流程详解

    Android定时开机的流程详解

    这篇文章给大家分享了Android定时开机及其实现流程,对此知识点有兴趣的朋友,可以学习参考下。
    2018-07-07

最新评论