AndroidUtils——LogUtils

本文详细探讨了Android开发中常用的LogUtils工具类,包括其工作原理、使用方法以及如何自定义日志打印,旨在帮助开发者更好地进行调试和问题排查。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


import android.util.Log;

/**
 * @author feathers
 * Log Utils
 */
public class LogUtils {
    /** 日志输出级别NONE */
    public static final int LEVEL_NONE = 0;
    /** 日志输出级别E */
    public static final int LEVEL_ERROR =1;
    /** 日志输出级别W */
    public static final int LEVEL_WARN = 2;
    /** 日志输出级别I */
    public static final int LEVEL_INFO = 3;
    /** 日志输出级别D */
    public static final int LEVEL_DEBUG = 4;
    /** 日志输出级别V */
    public static final int LEVEL_VERBOSE = 5;

    /** 日志输出时的TAG */
    private static final String mTag = "LogUtils";
    /** 是否允许输出log */
    private static int mDebuggable = LEVEL_VERBOSE;

    /** 以级别为 v 的形式输出LOG */
    public static void v(String msg) {
        if (mDebuggable >= LEVEL_VERBOSE) {
            Log.v(mTag, msg);
        }
    }

    /** 以级别为 d 的形式输出LOG */
    public static void d(String msg) {
        if (mDebuggable >= LEVEL_DEBUG) {
            Log.d(mTag, msg);
        }
    }

    /** 以级别为 i 的形式输出LOG */
    public static void i(String msg) {
        if (mDebuggable >= LEVEL_INFO) {
            Log.i(mTag, msg);
        }
    }

    /** 以级别为 w 的形式输出LOG */
    public static void w(String msg) {
        if (mDebuggable >= LEVEL_WARN) {
            Log.w(mTag, msg);
        }
    }

    /** 以级别为 w 的形式输出Throwable */
    public static void w(Throwable tr) {
        if (mDebuggable >= LEVEL_WARN) {
            Log.w(mTag, "", tr);
        }
    }

    /** 以级别为 w 的形式输出LOG信息和Throwable */
    public static void w(String msg, Throwable tr) {
        if (mDebuggable >= LEVEL_WARN && null != msg) {
            Log.w(mTag, msg, tr);
        }
    }

    /** 以级别为 e 的形式输出LOG */
    public static void e(String msg) {
        if (mDebuggable >= LEVEL_ERROR) {
            Log.e(mTag, msg);
        }
    }

    /** 以级别为 e 的形式输出Throwable */
    public static void e(Throwable tr) {
        if (mDebuggable >= LEVEL_ERROR) {
            Log.e(mTag, "", tr);
        }
    }

    /** 以级别为 e 的形式输出LOG信息和Throwable */
    public static void e(String msg, Throwable tr) {
        if (mDebuggable >= LEVEL_ERROR && null != msg) {
            Log.e(mTag, msg, tr);
        }
    }

    //指定tag为类名称

    /** 以级别为 v 的形式输出LOG */
    public static void v(Object tag, String msg) {
        if (mDebuggable >= LEVEL_VERBOSE) {
            Log.v(tag.getClass().getSimpleName(), msg);
        }
    }

    /** 以级别为 d 的形式输出LOG */
    public static void d(Object tag, String msg) {
        if (mDebuggable >= LEVEL_DEBUG) {
            Log.d(tag.getClass().getSimpleName(), msg);
        }
    }

    /** 以级别为 i 的形式输出LOG */
    public static void i(Object tag, String msg) {
        if (mDebuggable >= LEVEL_INFO) {
            Log.i(tag.getClass().getSimpleName(), msg);
        }
    }

    /** 以级别为 w 的形式输出LOG */
    public static void w(Object tag, String msg) {
        if (mDebuggable >= LEVEL_WARN) {
            Log.w(tag.getClass().getSimpleName(), msg);
        }
    }

    /** 以级别为 w 的形式输出Throwable */
    public static void w(Object tag, Throwable tr) {
        if (mDebuggable >= LEVEL_WARN) {
            Log.w(tag.getClass().getSimpleName(), "", tr);
        }
    }

    /** 以级别为 w 的形式输出LOG信息和Throwable */
    public static void w(Object tag, String msg, Throwable tr) {
        if (mDebuggable >= LEVEL_WARN && null != msg) {
            Log.w(tag.getClass().getSimpleName(), msg, tr);
        }
    }

    /** 以级别为 e 的形式输出LOG */
    public static void e(Object tag,String msg) {
        if (mDebuggable >= LEVEL_ERROR) {
            Log.e(tag.getClass().getSimpleName(), msg);
        }
    }

    /** 以级别为 e 的形式输出Throwable */
    public static void e(Object tag, Throwable tr) {
        if (mDebuggable >= LEVEL_ERROR) {
            Log.e(tag.getClass().getSimpleName(), "", tr);
        }
    }

    /** 以级别为 e 的形式输出LOG信息和Throwable */
    public static void e(Object tag, String msg, Throwable tr) {
        if (mDebuggable >= LEVEL_ERROR && null != msg) {
            Log.e(tag.getClass().getSimpleName(), msg, tr);
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值