运行日志是在程序运行中对其运行过程的一种追踪记录,在程序运行过程出现异常时的可方便我们追查出错的位置及其原因。
在 android 中也有 Log 但其并不完善,它并不会将日志记录在一个文件中,所以就要 自己去完善一个 Log 的类。
android.util.Log常用的方法有以下5个:
Log.v() Log.d() Log.i() Log.w() 以及 Log.e()。根据首字母分别对应VERBOSE,DEBUG,INFO,WARN,ERROR。
- Log.v 的调试颜色为黑色的,任何消息都会输出,这里的v代表verbose啰嗦的意思,平时使用就是Log.v(“”,””);
- Log.d的输出颜色是蓝色的,仅输出debug调试的意思,但他会输出上层的信息,过滤起来可以通过DDMS的Logcat标签来选择。
- Log.i的输出为绿色,一般提示性的消息information,它不会输出Log.v和Log.d的信息,但会显示i、w和e的信息。
- Log.w的意思为橙色,可以看作为warning警告,一般需要我们注意优化Android代码,同时选择它后还会输出Log.e的信息。
- Log.e为红色,可以想到error错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。
package com.example.…….libs;
import android.util.Log;
import com.example.…….MyApplication;
import com.example.…….util.FileUtil;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
public class MyLog {
// 日志文件总开关
private static Boolean MYLOG_SWITCH = true;
// 日志写入文件开关
private static Boolean MYLOG_WRITE_TO_FILE = true;
// 输入日志类型,w代表只输出告警信息等,v代表输出所有信息
private static char MYLOG_TYPE = 'v';
// 日志文件在sdcard中的路径
private static String MYLOG_PATH_SDCARD_DIR = "log";
// sd卡中日志文件的最多保存天数
private static int SDCARD_LOG_FILE_SAVE_DAYS = 0;
// 本类输出的日志文件名称
private static String MYLOGFILEName = "-Log.txt";
// 日志的输出格式
private static SimpleDateFormat myLogSdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
// 日志文件格式
private static SimpleDateFormat logfile = new SimpleDateFormat("yyyy-MM-dd");
public static void w(String tag, Object msg) { // 警告信息
log(tag, msg.toString(), 'w');
}
public static void e(String tag, Object msg) { // 错误信息
log(tag, msg.toString(), 'e');
}
public static void d(String tag, Object msg) {// 调试信息
log(tag, msg.toString(), 'd');
}
public static void i(String tag, Object msg) {//
log(tag, msg.toString(), 'i');
}
public static void v(String tag, Object msg) {
log(tag, msg.toString(), 'v');
}
public static void w(String tag, String text) {
log(tag, text, 'w');
}
public static void e(String tag, String text) {
log(tag, text, 'e');
}
public static void d(String tag, String text) {
log(tag, text, 'd');
}
public static void i(String tag, String text) {
log(tag, text, 'i');
}
public static void v(String tag, String text) {
log(tag, text, 'v');
}
/**
* 根据tag, msg和等级,输出日志
* @param tag
* @param msg
* @param level
*/
private static void log(String tag, String msg, char level) {
tag = MyApplication.TAG + ' ' + tag;
if (MYLOG_SWITCH) {//日志文件总开关
if ('e' == level && ('e' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) { // 输出错误信息
Log.e(tag, msg);
} else if ('w' == level && ('w' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
Log.w(tag, msg);
} else if ('d' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
Log.d(tag, msg);
} else if ('i' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
Log.i(tag, msg);
} else {
Log.v(tag, msg);
}
//日志写入文件开关
if (MYLOG_WRITE_TO_FILE)
writeLogtoFile(String.valueOf(level), tag, msg);
}
}
/**
* 打开日志文件并写入日志
* @param mylogtype
* @param tag
* @param text
*/
private static void writeLogtoFile(String mylogtype, String tag, String text) {
// 新建或打开日志文件
Date nowTime = new Date();
String needWriteFile = logfile.format(nowTime);
String needWriteMessage = myLogSdf.format(nowTime) + " " + mylogtype + " " + tag + " " + text + "\r\n";
FileUtil.writeStreamAppend(MyApplication.getContext(),
MYLOG_PATH_SDCARD_DIR,
needWriteFile + MYLOGFILEName,needWriteMessage);
}
/**
* 删除制定的日志文件
*/
public static void delFile() {
// 删除日志文件
String needDelFile = logfile.format(getDateBefore());
FileUtil.delFile(MyApplication.getContext(),
MYLOG_PATH_SDCARD_DIR, needDelFile + MYLOGFILEName);
}
/**
* 得到现在时间前的几天日期,用来得到需要删除的日志文件名
*/
private static Date getDateBefore() {
Date nowTime = new Date();
Calendar now = Calendar.getInstance();
now.setTime(nowTime);
now.set(Calendar.DATE, now.get(Calendar.DATE) - SDCARD_LOG_FILE_SAVE_DAYS);
return now.getTime();
}
}
转载请注明:隨習筆記 » android 的运行日志的记录类 Log