Android动态日志,一个简单的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): 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!!)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值