Android进阶:一、日志打印和保存策略,Android面试题库

if (saveLogStrategy != null || !isDebug) {
return;
}
final int MAX_BYTES = 1024 * 1024;
String diskPath = Environment.getExternalStorageDirectory().getAbsolutePath();
File cacheFile = context.getCacheDir();
if (cacheFile != null) {
diskPath = cacheFile.getAbsolutePath();
}
String folder = diskPath + File.separatorChar + “log”;
HandlerThread ht = new HandlerThread(“SohuLiveLogger.” + folder);
ht.start();
Handler handler = new SaveLogStrategy.WriteHandler(ht.getLooper(), folder, MAX_BYTES);
saveLogStrategy = new SaveLogStrategy(handler);
}

public static class WriteHandler extends Handler {

private final String folder;
private final int maxFileSize;

WriteHandler(@NonNull Looper looper, @NonNull String folder, int maxFileSize) {
super(checkNotNull(looper));
this.folder = checkNotNull(folder);
this.maxFileSize = maxFileSize;
}

@Override
public void handleMessage(@NonNull Message msg) {
String content = (String) msg.obj;
FileWriter fileWriter = null;
File logFile = getLogFile(folder, “logs”);
try {
fileWriter = new FileWriter(logFile, true);
writeLog(fileWriter, content);
fileWriter.flush();
fileWriter.close();
} catch (IOException e) {
if (fileWriter != null) {
try {
fileWriter.flush();
fileWriter.close();
} catch (IOException e1) {

}
}
}
}

我们使用HandlerThread来处理这个任务。HandlerThread是一个可以使用handler的Thread。当我们把消息保存到消息队列中去之后会在线程中去处理,又能保证不会产生很多线程。其实这里也可以使用instentservice实现,这个服务适合量大而不太耗时的任务。

最后在一个方法中统一打印和保存即可:

private void logPrint(int logLevel, Object msg) {
if (isDebug) {
String name = getFunctionName();
if (saveLogStrategy != null) {
saveLogStrategy.log(Log.ERROR, customTag, name + " - " + msg);
}
Log.println(logLevel, customTag, name + " - " + msg);
}
}

自定义的log策略还是比较简单,主要就是这个思想:打印日志信息详细,保存要采用队列的形式。一下是全部代码:

public class Logger {
public final static String tag = “”;
private static SaveLogStrategy saveLogStrategy;
private final static boolean logFlag = true;
private static Logger logger;
private int logLevel = Log.VERBOSE;
private static boolean isDebug = BuildConfig.DEBUG;
private String customTag = null;

private Logger(String customTag) {
this.customTag = customTag;
}

public void initSaveStrategy(Context context) {
if (saveLogStrategy != null || !isDebug) {
return;
}
final int MAX_BYTES = 1024 * 1024;
String diskPath = Environment.getExternalStorageDirectory().getAbsolutePath();
File cacheFile = context.getCacheDir();
if (cacheFile != null) {
diskPath = cacheFile.getAbsolutePath();
}
String folder = diskPath + File.separ

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

atorChar + “log”;
HandlerThread ht = new HandlerThread(“Logger.” + folder);
ht.start();
Handler handler = new SaveLogStrategy.WriteHandler(ht.getLooper(), folder, MAX_BYTES);
saveLogStrategy = new SaveLogStrategy(handler);
}

public static Logger getLogger(String tag) {
if (logger == null) {
logger = new Logger(tag);
}
return logger;
}

public static Logger getLogger() {
if (logger == null) {
logger = new Logger(tag);
}
return logger;
}

/**

  • Verbose(2) 级别日志
  • @param str String
    */
    public void v(Object str) {
    logLevel = Log.VERBOSE;
    logPrint(logLevel, str);
    }

/**

  • Debug(3) 级别日志
  • @param str String
    */
    public void d(Object str) {
    logLevel = Log.DEBUG;
    logPrint(logLevel, str);
    }

/**

  • Info(4) 级别日志
  • @param str String
    */
    public void i(Object str) {
    logLevel = Log.INFO;
    logPrint(logLevel, str);
    }

/**

  • Warn(5) 级别日志
  • @param str String
    */
    public void w(Object str) {
    logLevel = Log.WARN;
    logPrint(logLevel, str);
    }

/**

  • Error(6) 级别日志
  • @param str String
    */
    public void e(Object str) {
    logLevel = Log.ERROR;
    logPrint(logLevel, str);
    }

private void logPrint(int logLevel, Object msg) {
if (isDebug) {
String name = getFunctionName();
if (saveLogStrategy != null) {
saveLogStrategy.log(Log.ERROR, customTag, name + " - " + msg);
}
Log.println(logLevel, customTag, name + " - " + msg);
}
}

/**

  • 获取当前方法名
  • @return 方法名
    */
    private String getFunctionName() {
    StackTraceElement[] sts = Thread.currentThread().getStackTrace();
    if (sts == null) {
    return null;
    }

for (StackTraceElement st : sts) {
if (st.isNativeMethod()) {
continue;
}
if (st.getClassName().equals(Thread.class.getName())) {
continue;
}
if (st.getClassName().equals(this.getClass().getName())) {
continue;
}

Thread t = Thread.currentThread();
return “[Thread(id:” + t.getId() +
“, name:” + t.getName() +
“, priority:” + t.getPriority() +
“, groupName:” + t.getThreadGroup().getName() +
"): " + st.getFileName() + “:”

  • st.getLineNumber() + " " + st.getMethodName() + " ]";
    }
    return “”;
    }
    }

public class SaveLogStrategy {

@NonNull
private final Handler handler;

public SaveLogStrategy(@NonNull Handler handler) {
this.handler = checkNotNull(handler);
}

public void log(int level, @Nullable String tag, @NonNull String message) {
checkNotNull(message);
handler.sendMessage(handler.obtainMessage(level, message));
}

static class WriteHandler extends Handler {

private final String folder;
private final int maxFileSize;

WriteHandler(@NonNull Looper looper, @NonNull String folder, int maxFileSize) {
super(checkNotNull(looper));
this.folder = checkNotNull(folder);
this.maxFileSize = maxFileSize;
}

@SuppressWarnings(“checkstyle:emptyblock”)
@Override
public void handleMessage(@NonNull Message msg) {
String content = (String) msg.obj;
FileWriter fileWriter = null;
File logFile = getLogFile(folder, “logs”);

try {
fileWriter = new FileWriter(logFile, true);

writeLog(fileWriter, content);

fileWriter.flush();
fileWriter.close();
} catch (IOException e) {
if (fileWriter != null) {
try {
fileWriter.flush();
fileWriter.close();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值