EN

Android Tools - Log2File

Word count: 508Reading time: 2 min
2014/05/02
loading
Log2File工具类是用于Android程序将Log记录到文件中(如sd卡)的工具,应用场景:
  1. 无法连接电脑进行调试(usb线被usbotg占用)
  2. Log不容易被抓取
  3. Bug出现很随机,不是必出现
  4. 其他自己脑补

0.说明

这篇文章最早是在我的CSDN博客上面发布了:http://blog.csdn.net/grackergao/article/details/18322749 .现在讲他转移到了这里,代码的Github地址 :https://github.com/Gracker/Android-Utils/blob/master/Log2File.java

1.Log2File工具类源码

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Date;

import android.content.Context;
import android.os.Environment;

public class Log2File
{
  private static boolean logInit;
  private static BufferedWriter writer;

  private Log2File()
  {

  }

  /**
   * 初始化Log,创建log文件
   * @param ctx
   * @param fileName
   * @return
   */
  public static boolean init(Context ctx, String fileName)
  {
    if(!logInit)
    {
      String state = Environment.getExternalStorageState();
      if (Environment.MEDIA_MOUNTED.equals(state))
      {
        File sdDir = Environment.getExternalStorageDirectory();
        File logDir = new File(sdDir.getAbsolutePath() + "/log2file/" +
            ctx.getPackageName() + "/");

        try {
          if(!logDir.exists())
          {
            logDir.mkdirs();
          }

          File logFile = new File(logDir, fileName);
          logFile.createNewFile();

          writer = new BufferedWriter(new FileWriter(logFile, true));
          logInit = true;
        } catch (IOException e) {
          e.printStackTrace();
        }

      }

    }

    return logInit;
  }

  /**
   * 写一条log
   * @param msg
   */
  public static void w(String msg)
  {
    if(logInit)
    {
      try {
        Date date = new Date();
        writer.write("[" + date.toLocaleString() + "] " + msg);
        writer.newLine();
        writer.flush();
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
  }

  /**
   * 关闭log
   */
  public static void close()
  {
    if(logInit)
    {
      try {
        writer.close();
        writer = null;

      } catch (IOException e) {
        e.printStackTrace();
      }

      logInit = false;
    }
  }
}

2.Log2File类的使用

这个工具类的使用比较简单
1.首先调用init进行初始化
Log2File.init(context, fileName);
2.调用w()进行输出
Log2File.w(String msg);
3.使用完毕后,记得要关闭Log
Log2File.close();

关于我 && 博客

下面是个人的介绍和相关的链接,期望与同行的各位多多交流,三人行,则必有我师!

  1. 博主个人介绍 :里面有个人的微信和微信群链接。
  2. 本博客内容导航 :个人博客内容的一个导航。
  3. 个人整理和搜集的优秀博客文章 - Android 性能优化必知必会 :欢迎大家自荐和推荐 (微信私聊即可)
  4. Android性能优化知识星球 : 欢迎加入,多谢支持~

一个人可以走的更快 , 一群人可以走的更远

微信扫一扫

CATALOG
  1. 1. 0.说明
  2. 2. 1.Log2File工具类源码
  3. 3. 2.Log2File类的使用
  • 关于我 && 博客