在Android Log(一) 自定义带类名与方法名的Log中自定义了自己的LogUtil,但调试程序时,可能没有线数线,可以将log信息写到sd卡,方便后期查找错误。
public class LogUtil {
private static final String TAG = "LogUtil";
//Log开关
private static final String basePath = Environment.getExternalStorageDirectory().getAbsolutePath() + File.separator + "log" + File.separator;
private static String fileName = null;
private static boolean isAppend = false;
private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
private static final boolean DEBUG = true;
public static void d(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("d", logStr);
Log.d(TAG, logStr);
}
}
public static void e(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("e", logStr);
Log.e(TAG, logStr);
}
}
public static void i(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("i", logStr);
Log.i(TAG, logStr);
}
}
public static void v(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("v", logStr);
Log.v(TAG, logStr);
}
}
public static void w(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("w", logStr);
Log.e(TAG, logStr);
}
}
public static void wtf(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("wtf", logStr);
Log.wtf(TAG, logStr);
}
}
public static void println(String message) {
if (DEBUG) {
String logStr = createMessage(message);
writeLog2SDCard("println", logStr);
Log.println(Log.INFO, TAG, logStr);
}
}
/**
* 获取有类名与方法名的logString
*
* @param rawMessage
* @return
*/
private static String createMessage(String rawMessage) {
/**
* Throwable().getStackTrace()获取的是程序运行的堆栈信息,也就是程序运行到此处的流程,以及所有方法的信息
* 这里我们为什么取2呢?0是代表createMessage方法信息,1是代表上一层方法的信息,这里我们
* 取它是上两层方法的信息
*/
StackTraceElement stackTraceElement = new Throwable().getStackTrace()[2];
String fullClassName = stackTraceElement.getClassName();
String className = fullClassName.substring(fullClassName.lastIndexOf(".") + 1);
return className + "." + stackTraceElement.getMethodName() + "(): " + rawMessage;
}
/**
* 程序每次运行创建一个新的txt,以时间为文件名
*
* @param type log的类型
* @param context log的内容
*/
private static void writeLog2SDCard(String type, String context) {
if (fileName == null)
fileName = sdf.format(new Date(System.currentTimeMillis())) + ".txt";
File file = new File(basePath + fileName);
String dateStr = sdf.format(new Date(System.currentTimeMillis()));
context = dateStr + "==" + type + "==" + context;
try {
if (!file.exists()) {
file.getParentFile().mkdirs();
file.createNewFile();
}
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file, isAppend)));
bufferedWriter.write(context);
bufferedWriter.newLine();
bufferedWriter.flush();
bufferedWriter.close();
if (!isAppend) {
isAppend = true;
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
最后在Manifest.xml中加上权限:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>