Android Log(二) 将Log信息写到sd卡中并带时间

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"/>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值