首页 > 移动平台 > 详细

Android日志输出工具类

时间:2019-05-13 21:28:00      阅读:120      评论:0      收藏:0      [点我收藏+]
package com.rctd.tmzs.util;


import android.util.Log;


/** ?
?* 日志输出工具类
?* @author ? ?WuHao; Email: 1024778537@qq.com ?
?* @version ? V1.0; ?Date: ?2014-05-26 11:35:20 ?
?*/ ?
public class LogUtil {


private static String tag = "LogUtil";

private int logLevel = Log.VERBOSE;
private static final boolean isDebug = true;
private static LogUtil instance = null;


public static synchronized LogUtil getInstance() {
return getInstance(Log.VERBOSE);
}

public static synchronized LogUtil getInstance(int level) {
if (instance == null)
instance = new LogUtil();
if (level >= 2)
instance.setLevel(level);
return instance;
}


private LogUtil() {

}

public void setLevel(int level){
this.logLevel = level;
}


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;
}
return "[" + Thread.currentThread().getName() + "(" + Thread.currentThread().getId() + "): " + st.getFileName() + ":" + st.getLineNumber() + "]";
}
return null;
}


private void outMsg(Object str) {
String msg = (str == null ? "" : str.toString());
String name = getFunctionName();
String ls = (name == null ?

msg.toString() : (name + " - " + msg));
if (logLevel == Log.DEBUG) {
Log.d(tag, ls);
} else if (logLevel == Log.INFO) {
Log.i(tag, ls);
} else if (logLevel == Log.WARN) {
Log.w(tag, ls);
} else if (logLevel == Log.ERROR) {
Log.e(tag, ls);
} else {
Log.v(tag, ls);
}
}


public void out(Object msg) {
if (isDebug) {
outMsg(msg);
}
}
}

Android日志输出工具类

原文:https://www.cnblogs.com/mqxnongmin/p/10858912.html

(0)
(0)
   
举报
评论 一句话评论(0
分享档案
最新文章
教程昨日排行
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!