将logcat写进SD卡(能追加)并按文件大小进行删除

有参考他人博客,有篇博客是根据文件日期进行删除的 

原文地址http://xiangqianppp-163-com.iteye.com/blog/1417743

将日志记录在文件中并每天生成一个日志文件 原文地址:http://easion-zms.iteye.com/blog/981568

Android - 文件读写操作 总结  原文地址:http://blog.csdn.net/ztp800201/article/details/7322110

 

package com.gxt.vodbox;

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

import java.text.SimpleDateFormat;  
 
import java.util.Date;  


import android.os.Environment;
import android.util.Log;


public class MyLog {

 private static Boolean MYLOG_SWITCH=true; // 日志文件总开关
 private static Boolean MYLOG_WRITE_TO_FILE=true;// 日志写入文件开关
 private static char MYLOG_TYPE='v';// 输入日志类型,w代表只输出告警信息等,v代表输出所有信息
 private static int SDCARD_LOG_FILE_SAVE_DAYS = 0;// sd卡中日志文件的最多保存天数
 private static String MYLOGFILEName = "mylogfile.txt";// 本类输出的日志文件名称
 private static SimpleDateFormat myLogSdf = new SimpleDateFormat(
   "yyyy-MM-dd HH:mm:ss");// 日志的输出格式
 private static SimpleDateFormat logfile = new SimpleDateFormat("yyyy-MM-dd");// 日志文件格式

 static File file;
 public static void w(String tag, Object msg) { // 警告信息
  
  log(tag, msg.toString(), 'w');
 }

 public static void e(String tag, Object msg) { // 错误信息
  log(tag, msg.toString(), 'e');
 }

 public static void d(String tag, Object msg) {// 调试信息
  log(tag, msg.toString(), 'd');
 }

 public static void i(String tag, Object msg) {//日志信息
  log(tag, msg.toString(), 'i');
 }

 public static void v(String tag, Object msg) {//所有信息
  log(tag, msg.toString(), 'v');
 }

 public static void w(String tag, String text) {
  log(tag, text, 'w');
 }

 public static void e(String tag, String text) {
  log(tag, text, 'e');
 }

 public static void d(String tag, String text) {
  log(tag, text, 'd');
 }

 public static void i(String tag, String text) {
  log(tag, text, 'i');
 }

 public static void v(String tag, String text) {
  log(tag, text, 'v');
 }

 /**
  * 根据tag, msg和等级,输出日志
  *
  * @param tag
  * @param msg
  * @param level
  * @return void
  * @since v 1.0
  */
 private static void log(String tag, String msg, char level) {
  if (MYLOG_SWITCH) {
   if ('e' == level && ('e' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) { // 输出错误信息
    Log.e(tag, msg);
   } else if ('w' == level && ('w' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
    Log.w(tag, msg);
   } else if ('d' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
    Log.d(tag, msg);
   } else if ('i' == level && ('d' == MYLOG_TYPE || 'v' == MYLOG_TYPE)) {
    Log.i(tag, msg);
   } else {
    Log.v(tag, msg);
   }
   if (MYLOG_WRITE_TO_FILE)
    writeLogtoFile(String.valueOf(level), tag, msg);
  }
 }

 /**
  * 打开日志文件并写入日志
  *
  * @return
  * **/
 private static void writeLogtoFile(String mylogtype, String tag, String text) {// 新建或打开日志文件
  // 判断sd卡是否存在
  if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
   try{
   Date nowtime = new Date();   
   String needWriteMessage = myLogSdf.format(nowtime) + "    " + mylogtype
     + "    " + tag + "    " + text;
    file = new File(Environment.getExternalStorageDirectory(), MYLOGFILEName);
      
    FileWriter filerWriter = new FileWriter(file, true);//后面这个参数代表是不是要接上文件中原来的数据,不进行覆盖  
             BufferedWriter bufWriter = new BufferedWriter(filerWriter); 
            
             bufWriter.write(needWriteMessage+"\r\n");  
             bufWriter.newLine();  
             bufWriter.close();  
             filerWriter.close();
   }
    catch (IOException e) {
    // TODO Auto-generated catch block 
    e.printStackTrace();
   }
   
  }
            
             try {
     readFileSdcardFile(MYLOGFILEName);
    } catch (IOException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
 }
 
/**
 * 获取文件大小进行删除大于2M删除
 */
 public static  void readFileSdcardFile(String fileName) throws IOException {
  
  int l = fileName.length();
  Log.i("MyLog1", l+"");
  Integer it = new Integer(l);
  byte b = it.byteValue();
  int i = b / 1024/1024;
  Log.i("MyLog2", i+"");
  if (i > 2) {
   file.delete();
  }
 }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值