一个简单的Android日志类

Android自带的日志类不支持显示文件名和行号,调试时很不方便。而第三方日志库往往又太重。所以自己对Android自带的日志类做了一个简单的封装,主要是调试时使用,不考虑日志丢失和性能问题。日志的输出如下:

08-12 13:26:25.557 31285 31285 D com.tq.test: [TestFragment.kt:85 com.tq.test.fragment.TestFragment$subscribeUi$5.onChanged] foo bar

用法如下:

// 在Activity或Fragment中
val someValue = "abc";
getLogger().debug(someValue)
getLogger().debug(someValue, x, y, z)
getLogger().error(ex)

// CrashHandler
package com.tq.test

import android.os.Process
import com.tq.test.utility.Logger

class DefaultExceptionHandler(
        private val packageName: String,
        private val next: Thread.UncaughtExceptionHandler? = null
): Thread.UncaughtExceptionHandler {
    
    override fun uncaughtException(thread: Thread, error: Throwable) {
        val logger = Logger.getLogger(packageName)
        logger.error(error, "uncaught exception", thread)

        next?.uncaughtException(thread, error)
        Process.killProcess(Process.myPid())
    }
}

Thread.setDefaultUncaughtExceptionHandler(DefaultExceptionHandler(
        getPackageName(),
        Thread.getDefaultUncaughtExceptionHandler()
))

源代码如下:

package com.tq.utility

import androidx.appcompat.app.AppCompatActivity
import androidx.fragment.app.Fragment
import android.content.Context
import android.util.Log

class Logger private constructor(val defaultTag: String = "") {

    fun debug(vararg values: Any?) = Log.d(defaultTag, makeMessage(values))
    fun info(vararg values: Any?) = Log.i(defaultTag, makeMessage(values))
    fun warn(vararg values: Any?) = Log.w(defaultTag, makeMessage(values))
    fun error(error: Throwable, vararg values: Any?) = Log.e(defaultTag, makeMessage(values), error)

    private fun makeMessage(values: Array<out Any?>): String {
        // TOOD handle native method
        
        var fileName = "unknown"
        var lineNumber = -1
        var className = "unknown"
        var methodName ="unknown"
        
        val throwable = Throwable()
        val stacks = throwable.getStackTrace()
        val depth = 2
        if (stacks.size > depth) {
            val stack = stacks[depth]
            fileName = stack.getFileName()
            lineNumber = stack.getLineNumber()
            className = stack.getClassName()
            methodName = stack.getMethodName()
        }

        val valueString = values.map{ it?.toString() ?: "null" }.joinToString()
        return "[$fileName:$lineNumber $className.$methodName] $valueString"
    }

    companion object {
        fun getLogger(tag: String): Logger {
            return Logger(tag)
        }

        fun getLogger(context: Context) = getLogger(context.getPackageName())
    }
}

fun AppCompatActivity.getLogger() = Logger.Companion.getLogger(this)
fun Fragment.getLogger() = Logger.Companion.getLogger(activity!!)

 

转载于:https://my.oschina.net/u/131191/blog/3089338

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值