Android 自定义Log类,动态管理你的日志

Android Logger

最近看了公司的Log工具类,觉得有点简单。决定自己实现一个,Logger, 一个可以控制Log输出不同场景的工具类

package com.android.chocolate.util

import android.util.Log
import java.lang.NullPointerException


/**
 * <p>
 * 需求一:可以开启关闭所有的Log打印
 * 需求二:指定指打印某一个类型的Log,设置则生效
 * 需求三:指定指打印某一个类型的Log以上的日志,设置则生效
 * </p>
 * <description>需求二、三 需要用户手动开启,默认是不开启的</description>
 * @author ricky  2022/2/25 13:57
 * @since 1.0
 */
object Logger {
   

    // default TAG
    private const val TAG = "Logger"

    // 设置为false,则不会打印出日志
    private const val isOpen = false

    // 只单独显示一个类型的日志,当你需要的时候 可以对它进行设置 默认显示全部
    private var onlyLogCategory: Int? = null

    // 是否显示包含它及以上的高等级日志,默认不开启
    private var isExpand = false

    /**
     * 设置只显示这个一个类型的日志
     */
    @Synchronized
    fun setOnlyLogCategory(style: Style) {
   
        onlyLogCategory = style.getMark()
    }

    @Synchronized
    fun getOnlyLogCategory() = onlyLogCategory

    /**
     * 需要配合setOnlyLogCategory一起使用,单开启无任何效果
     * @see Logger.setOnlyLogCategory
     *
     */
    @Synchronized
    fun setExpand(status: Boolean) {
   
        isExpand = status
    }

    @Synchronized
    fun getExpand() = isExpand

    /**
     * Info
     */
    fun 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android开发中,我们经常会使用Log来打印日志。但是,Android原生的Log输出信息有限,为了更好地输出和管理日志,我们可以自定义LogUtil。 下面是一个简单的LogUtil,可以自定义输出日志级别、输出信息格式等: ```java public class LogUtil { private static final String TAG = "LogUtil"; private static boolean sDebug = true; // 是否打印日志 private static boolean sSaveLog = false; // 是否保存日志到文件 private static String sLogPath = Environment.getExternalStorageDirectory().getPath() + "/log.txt"; // 日志保存路径 public static void setDebug(boolean debug) { sDebug = debug; } public static void setSaveLog(boolean saveLog) { sSaveLog = saveLog; } public static void setLogPath(String logPath) { sLogPath = logPath; } public static void v(String msg) { if (sDebug) { Log.v(TAG, msg); } saveLogToFile("V", TAG, msg); } public static void d(String msg) { if (sDebug) { Log.d(TAG, msg); } saveLogToFile("D", TAG, msg); } public static void i(String msg) { if (sDebug) { Log.i(TAG, msg); } saveLogToFile("I", TAG, msg); } public static void w(String msg) { if (sDebug) { Log.w(TAG, msg); } saveLogToFile("W", TAG, msg); } public static void e(String msg) { if (sDebug) { Log.e(TAG, msg); } saveLogToFile("E", TAG, msg); } private static void saveLogToFile(String level, String tag, String msg) { if (sSaveLog) { try { File file = new File(sLogPath); FileWriter fw = new FileWriter(file, true); BufferedWriter bw = new BufferedWriter(fw); bw.write("[" + level + "] " + tag + ": " + msg + "\n"); bw.close(); fw.close(); } catch (IOException e) { Log.e(TAG, "saveLogToFile: " + e.getMessage()); } } } } ``` 使用方法: ```java LogUtil.setDebug(true); // 设置是否打印日志 LogUtil.setSaveLog(true); // 设置是否保存日志到文件 LogUtil.setLogPath("/sdcard/log.txt"); // 设置日志保存路径 LogUtil.v("verbose log"); LogUtil.d("debug log"); LogUtil.i("info log"); LogUtil.w("warning log"); LogUtil.e("error log"); ``` 以上就是一个简单的LogUtil的实现,可以根据自己的需求进行修改和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值