一、前言:
Log日志在Android项目开发中的作用非常重要,但项目越做越大,开发者会面临很多问题,比如管理各种不同的Log,不同版本控制是否输入Log等。Timber是一个轻量级的第三方库,能够帮助开发者更好的使用Android Log。
1、Timber 介绍
Timeber的使用主要通过添加Tree实例,添加Tree实例可以通过方法Timber.plant完成。实例化Tree需要尽量早,推荐在项目Application的onCreate()方法中完成。
其中,DebugTree自动实例化,是Timber中已经实现了tree的类,可直接拿来用,并在使用他的类中以类名为其TAG,但是其他的Tree不会自动实例化,需要进行手动实现扩展Timber.Tree实现。
二、使用:
1、下载
在build.gradle中
implementation 'com.jakewharton.timber:timber:4.7.0'
2、注册
//在onCreate()中
if (BuildConfig.DEBUG) {
Timber.plant(new Timber.DebugTree());
} else {
Timber.plant(new CrashReportingTree());
}
private static class CrashReportingTree extends Timber.Tree {
@Override
protected void log(int priority, String tag, String message, Throwable t) {
}
}
注意:在日常使用中,我们除了开发中需要日志外,其他并没有过硬的需求.
所以,初始化时,我们可以去掉未成熟的CrashReportingTree,仅设置DebugTree:
/**
* 仅在Debug时初始化Timber
*/
if (BuildConfig.DEBUG) {
Timber.plant(new Timber.DebugTree());
}
3、使用
//指定tag的名字,默认是的tag是当前的Activity类名
//Timber.tag("activityName");
Timber.d("这个是d");
Timber.v("这个是v");
Timber.i("这个是i");
Timber.e("这个是e");
结果:
2021-02-22 13:46:11.379 22813-22813/com.sumansoul.myviewdemo D/MainActivity: 这个是d
2021-02-22 13:46:11.380 22813-22813/com.sumansoul.myviewdemo I/MainActivity: 这个是i
2021-02-22 13:46:11.380 22813-22813/com.sumansoul.myviewdemo E/MainActivity: 这个是e