自定义 Android 日志工具

LogUtils

在实际开发中,当应用程序发布时,我们往往需要清除程序中打印的日志。
一方面是减少资源的消耗,另一方面我们不希望让用户看到一些用于测试的敏感数据。
而一行行的删既费时又费力,而且也有可能没有完全清除。
此外,清除日志后对应用后继的维护与开发带来不便,因为我们也许还会需要那些打印出来的日志。
此工具类则解决这样一个问题:
当应用需要发布的时候,只要将LEVEL_STATUS改为LEVEL_NONE,日志信息就会被屏蔽。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import android.util.Log;

/**
* 此工具类对系统提供的打印日志类Log进行了封装
* Created by Jockio on 2016/5/24
*/
public class LogUtils {
private final static int LEVEL_NONE = 0;
private final static int LEVEL_VERBOSE = 1;
private final static int LEVEL_DEBUG = 2;
private final static int LEVEL_INFO = 3;
private final static int LEVEL_WARN = 4;
private final static int LEVEL_ERROR = 5;

private static String TAG = "LogUtils";
//指示当前的打印状态
private static int LEVEL_STATUS = LEVEL_ERROR;

public static void v(String tag, String msg){
if(LEVEL_STATUS >= LEVEL_VERBOSE){
Log.v(tag, msg);
}
}

public static void d(String tag, String msg){
if(LEVEL_STATUS >= LEVEL_DEBUG){
Log.d(tag, msg);
}
}

public static void i(String tag, String msg){
if(LEVEL_STATUS >= LEVEL_INFO){
Log.i(tag, msg);
}
}

public static void w(String tag, String msg){
if(LEVEL_STATUS >= LEVEL_WARN){
Log.w(tag, msg);
}
}

public static void e(String tag, String msg){
if(LEVEL_STATUS >= LEVEL_ERROR){
Log.e(tag, msg);
}
}

public static void v(String msg){
if(LEVEL_STATUS >= LEVEL_VERBOSE){
Log.v(TAG, msg);
}
}

public static void d(String msg){
if(LEVEL_STATUS >= LEVEL_DEBUG){
Log.d(TAG, msg);
}
}

public static void i(String msg){
if(LEVEL_STATUS >= LEVEL_INFO){
Log.i(TAG, msg);
}
}

public static void w(String msg){
if(LEVEL_STATUS >= LEVEL_WARN){
Log.w(TAG, msg);
}
}

public static void e(String msg){
if(LEVEL_STATUS >= LEVEL_ERROR){
Log.e(TAG, msg);
}
}
}