自己封装的Log优化工具类

/**
 * Log方法优化工具类
 * 只在Debug模式下打印log并添加 log代码定位
 */

public class L {

    private L() {
        /* cannot be instantiated */
        throw new UnsupportedOperationException("cannot be instantiated");
    }

    private static final String TAG = "试验田";
    private static boolean isDebug = BuildConfig.isDebug;

    // 下面四个是默认tag的函数
    public static void i(String msg) {
        if (!isDebug) return;
        Log.i(TAG, getLocation());
        Log.i(TAG, msg);
    }

    public static void d(String msg) {
        if (!isDebug) return;
            Log.d(TAG, getLocation());
            Log.d(TAG, msg);
    }

    public static void e(String msg) {
        if (!isDebug) return;
            Log.e(TAG, getLocation());
            Log.e(TAG, msg);
    }

    public static void v(String msg) {
        if (!isDebug) return;
            Log.v(TAG, getLocation());
            Log.v(TAG, msg);
    }

    // 下面是传入自定义tag的函数
    public static void i(String tag, String msg) {
        if (!isDebug) return;
            Log.i(tag, getLocation());
            Log.i(tag, msg);
    }

    public static void d(String tag, String msg) {
        if (!isDebug) return;
            Log.d(tag, getLocation());
            Log.d(tag, msg);
    }

    public static void e(String tag, String msg) {
        if (!isDebug) return;
            Log.e(tag, getLocation());
            Log.e(tag, msg);
    }

    public static void v(String tag, String msg) {
        if (!isDebug) return;
            Log.v(tag, getLocation());
            Log.v(tag, msg);
    }

    public static void iJson(String msg) {
        if (!isDebug) return;
        Log.i(TAG, getLocation());
        Log.i(TAG, "\n"+getPrettyJson(msg));
    }

    public static void dJson(String msg) {
        if (!isDebug) return;
        Log.d(TAG, getLocation());
        Log.d(TAG, "\n"+getPrettyJson(msg));
    }

    public static void eJson(String msg) {
        if (!isDebug) return;
        Log.e(TAG, getLocation());
        Log.e(TAG, "\n"+getPrettyJson(msg));
    }

    public static void vJson(String msg) {
        if (!isDebug) return;
        Log.v(TAG, getLocation());
        Log.v(TAG, "\n"+getPrettyJson(msg));
    }

    public static void iJson(String tag, String msg) {
        if (!isDebug) return;
        Log.i(tag, getLocation());
        Log.i(tag, "\n"+getPrettyJson(msg));
    }

    public static void dJson(String tag, String msg) {
        if (!isDebug) return;
        Log.d(tag, getLocation());
        Log.d(tag, "\n"+getPrettyJson(msg));
    }

    public static void eJson(String tag, String msg) {
        if (!isDebug) return;
        Log.e(tag, getLocation());
        Log.e(tag, "\n"+getPrettyJson(msg));
    }

    public static void vJson(String tag, String msg) {
        if (!isDebug) return;
        Log.v(tag, getLocation());
        Log.v(tag, "\n"+getPrettyJson(msg));
    }

    private static StackTraceElement getTargetStackTraceElement() {
        // find the target invoked method
        StackTraceElement targetStackTrace = null;
        boolean shouldTrace = false;
        StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace();
        for (StackTraceElement stackTraceElement : stackTrace) {
            boolean isLogMethod = stackTraceElement.getClassName().equals(L.class.getName());
            if (shouldTrace && !isLogMethod) {
                targetStackTrace = stackTraceElement;
                break;
            }
            shouldTrace = isLogMethod;
        }
        return targetStackTrace;
    }

    private static String getLocation(){
        StackTraceElement targetStackTraceElement = getTargetStackTraceElement();
        //实现定位效果的原因是 xxx.java:112  的格式会被自动识别实现定位的效果
        return "(" + targetStackTraceElement.getFileName() + ":" + targetStackTraceElement.getLineNumber() + ")";
    }

    private static String getPrettyJson(String jsonStr) {
        try {
            jsonStr = jsonStr.trim();
            if (jsonStr.startsWith("{")) {
                JSONObject jsonObject = new JSONObject(jsonStr);
                return jsonObject.toString(2);
            }
            if (jsonStr.startsWith("[")) {
                JSONArray jsonArray = new JSONArray(jsonStr);
                return jsonArray.toString(2);
            }
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return "Invalid Json, Please Check: " + jsonStr;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值