android 日记log保存到本地简单方法

安卓日常开发中,经常需要打印日记,经常需要把log输入到本地查看,本demo是把日记输出到本地的简单示例:

1.初始化保存路径(实例中为SD卡下: /storage/emulated/0/interprenter)
 /**
 * 初始化目录
 */
private void init(Context context) {
    if (Environment.getExternalStorageState().equals(
            Environment.MEDIA_MOUNTED)) {// 优先保存到SD卡中
        PATH_LOGCAT = Environment.getExternalStorageDirectory()
                .getAbsolutePath() + File.separator + "interprenter";
    } else {// 如果SD卡不存在,就保存到本应用的目录下
        PATH_LOGCAT = context.getFilesDir().getAbsolutePath()
                + File.separator + "interprenter";
    }
    File file = new File(PATH_LOGCAT);
    if (!file.exists()) {
        file.mkdirs();
        LogUtils.e("创建文件夹");
    }
    LogUtils.e(PATH_LOGCAT);
}
2.编写一个线程,用户收集和写入日记
private class LogDumper extends Thread {

    private Process logcatProc;
    private BufferedReader mReader = null;
    private boolean mRunning = true;
    String cmds = null;
    private String mPID;
    private FileOutputStream out = null;

    public LogDumper(String pid, String dir) {
        mPID = pid;
        try {
            out = new FileOutputStream(new File(dir, "log_"
                    + getFileName() + ".log"));

        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        /**
         *
         * 日志等级:*:v , *:d , *:w , *:e , *:f , *:s
         *
         * 显示当前mPID程序的 E和W等级的日志.
         *
         * */

        // cmds = "logcat *:e *:w | grep \"(" + mPID + ")\"";
        // cmds = "logcat  | grep \"(" + mPID + ")\"";//打印所有日志信息
        // cmds = "logcat -s way";//打印标签过滤信息
        cmds = "logcat *:e *:i | grep \"("
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

木子102

你的励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值