android日志打印工具类

给大家献上一款好用的日志打印工具。大家在平时的开发中用的最多的可能就是 Log.i("",""),Log.e("","")...,在要查看的日志比较少的情况下,这种方法用起来确实方便,很容易写,也很容易查看,然而不知道大家有没有遇到过这样一种情况,如果你要查看的数据量非常大,然后用Log类打印出来以后,却发现只显示了一部分数据,大部分数据被截断了。
是的,log打印出来的日志长度是有限的,我之前由于要分析一段从服务器获取的数据,数据量比较大,用log类打印之后只能看到一部分数据,大部分数据都 被截断了,后来就自己写了一个日志打印工具类,把日志打印到手机SD卡上,这样就能看到完整的数据,该工具我已封装好,分享给大家。
public class LogTools {

    public static void dailyLog(String title, String log) {
        try {
            // 如果外部存储卡存在且可读写
            if (Environment.getExternalStorageState().equals(
                    Environment.MEDIA_MOUNTED)) {
                Date date = new Date();
                SimpleDateFormat df = new SimpleDateFormat("yyyyMMdd");
                SimpleDateFormat tf = new SimpleDateFormat("HH:mm:ss:SSS");
                String path = Environment.getExternalStorageDirectory()
                        .getAbsolutePath()
                        + File.separator
                        + "mylog"
                        + File.separator
                        + "debuglog["
                        + df.format(date)
                        + "]"
                        + ".txt";
                File file = new File(path);
                // 如果文件不存在,则重新创建
                if (!file.exists()) {
                    // 最后一级是文件,前面是路径,如果路径不存在则创建路径
                    if (!file.getParentFile().exists()) {
                        file.getParentFile().mkdirs();
                    }
                    // 创建日志文件
                    file.createNewFile();
                }
                //写日志
                FileWriter fw = new FileWriter(file, true);
                fw.flush();
                fw.write("\n[" + df.format(date) +"--"+ tf.format(date) + "]\n");
                fw.write(title + ": " + log);
                fw.write("\n\n");
                fw.close();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

调用:
public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        LogTools.dailyLog("我的日志", "----33222211111111118838777777777777766666666666444444444");
    }
}

编程技巧