Android打印日志,实现快速定位源代码

拿来主义而已 直接看源码
方式一:

import android.util.Log;

/**
 * Created by Administrator on 2018/8/8.
 */
public class LogUtil {

    public static void PrintD(String content, Object... args) {
        for (int i = 0; i < Thread.currentThread().getStackTrace().length; i++) {
            String realContent = getContent(content, i, args);
            Log.d("default", realContent);
        }
    }

    public static void PrintD(String tag, String content, Object... args) {
        Log.d(tag, getContent(content, 4, args));
    }

    private static String getNameFromTrace(StackTraceElement[] traceElements, int place) {
        StringBuilder taskName = new StringBuilder();
        if (traceElements != null && traceElements.length > place) {
            StackTraceElement traceElement = traceElements[place];
            taskName.append(traceElement.getMethodName());
            taskName.append("(").append(traceElement.getFileName()).append(":").append(traceElement.getLineNumber()).append(")");
        }
        return taskName.toString();
    }

    private static String getContent(String msg, int place, Object... args) {
        try {
            String sourceLinks = getNameFromTrace(Thread.currentThread().getStackTrace(), place);
            return sourceLinks + String.format(msg, args);
        } catch (Throwable throwable) {
            return msg;
        }
    }
}

调用

  LogUtil.PrintD("Exception",  e.getMessage());

方式二:

Log.e("Exception", "============================================================");
      StackTraceElement[] ste = e.getStackTrace();
      for (int i = 1; i < ste.length; i++) {
          String msg = "Class:" + ste[i].getClassName() + ", Line: " + ste[i].getLineNumber() + ", MethodName:" + ste[i].getMethodName();
          Log.e("Exception", msg);
      }
Log.e("Exception", "============================================================");

参考文章 :
Android打印日志,实现快速定位源代码 ——大头呆
Android 从StackTraceElement反观Log库 —— 鸿洋_

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值