public class Logger {
/**
* log tag
*/
private String tagName = "MoGuLogger";// tag name // private static int logLevel = Log.VERBOSE; private static int logLevel = Log.VERBOSE; private static Logger inst; private Lock lock; private Logger() {
lock = new ReentrantLock();
} public static synchronized Logger getLogger(Class<?> key) {
if (inst == null) {
inst = new Logger();
} return inst;
} private String getFunctionName() {
StackTraceElement[] sts = Thread.currentThread().getStackTrace(); if (sts == null) {
return null;
} Log.i("TAG", "start" + "threadName:" + Thread.class.getName() + " className:"
+ this.getClass().getName());
for (StackTraceElement st : sts) {
Log.i("TAG", st.getClassName());
}
Log.i("TAG", "end");
for (StackTraceElement st : sts) {
Log.i("TAG", st.getClassName());
if (st.isNativeMethod()) {
continue;
} if (st.getClassName().equals(Thread.class.getName())) {
continue;
} if (st.getClassName().equals(this.getClass().getName())) {
continue;
}
return "[" + st.getFileName() + ":" + st.getLineNumber() + "]";
} return null;
} private String createMessage(String msg) {
String functionName = getFunctionName();
long threadId = Thread.currentThread().getId();
String currentTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS").format(new Date());
String message = (functionName == null ? msg : (functionName + " - "
+ String.valueOf(threadId) + " - " + msg));
return currentTime + " - " + message;
} /**
* log.i
*/
public void i(String format, Object... args) {
if (logLevel <= Log.INFO) {
lock.lock();
try {
String message = createMessage(getInputString(format, args));
Log.i(tagName, message);
} finally {
lock.unlock();
}
}
} /**
* log.v
*/
public void v(String format, Object... args) {
if (logLevel <= Log.VERBOSE) {
lock.lock();
try {
String message = createMessage(getInputString(format, args));
Log.v(tagName, message);
} finally {
lock.unlock();
}
}
} /**
* log.d
*/
public void d(String format, Object... args) {
if (logLevel <= Log.DEBUG) {
lock.lock();
try {
String message = createMessage(getInputString(format, args));
Log.d(tagName, message);
} finally {
lock.unlock();
}
}
} /**
* log.e
*/
public void e(String format, Object... args) {
if (logLevel <= Log.ERROR) {
lock.lock();
try {
String message = createMessage(getInputString(format, args));
Log.e(tagName, message);
} finally {
lock.unlock();
}
}
} private String getInputString(String format, Object... args) {
if (format == null) {
return "null log format";
} return String.format(format, args);
} /**
* log.error
*/
public void error(Exception e) {
if (logLevel <= Log.ERROR) {
StringBuffer sb = new StringBuffer();
lock.lock();
try {
String name = getFunctionName();
StackTraceElement[] sts = e.getStackTrace(); if (name != null) {
sb.append(name + " - " + e + "\r\n");
} else {
sb.append(e + "\r\n");
}
if (sts != null && sts.length > 0) {
for (StackTraceElement st : sts) {
if (st != null) {
sb.append("[ " + st.getFileName() + ":" + st.getLineNumber() + " ]\r\n");
}
}
}
Log.e(tagName, sb.toString());
} finally {
lock.unlock();
}
}
} /**
* log.d
*/
public void w(String format, Object... args) {
if (logLevel <= Log.WARN) {
lock.lock();
try {
String message = createMessage(getInputString(format, args));
Log.w(tagName, message);
} finally {
lock.unlock();
}
}
} /**
* set log level
*/ public void setLevel(int l) {
lock.lock();
try {
logLevel = l;
} finally {
lock.unlock();
}
}
}

开源TT框架上的日志类的更多相关文章

  1. 字节开源RPC框架Kitex的日志库klog源码解读

    前言 这篇文章将着重于分析字节跳动开源的RPC框架Kitex的日志库klog的源码,通过对比Go原生日志库log的实现,探究其作出的改进. 为了平滑学习曲线,我写下了这篇分析Go原生log库的文章,希 ...

  2. 高性能日志类KLog(已开源代码)

    项目开源地址:https://github.com/ihambert/KLog  上回介绍了超简易日志类,但他有诸多的局限性,注定了不能作为一个网站的日志类. 那什么样的日志类才能用于网站呢.首先来假 ...

  3. 如何优雅的阅读 GitHub 上开源 js 框架和库的源码

    如何优雅的阅读 GitHub 上开源 js 框架和库的源码 step 先总后分,即先了解一下啊框架的大体架构,又一个全局的认识,在选择某些和感兴趣的部分,仔细阅读,各个击破: 带着问题阅读,用到了什么 ...

  4. python3+selenium框架设计03-封装日志类

    首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...

  5. python3+requests库框架设计02-封装日志类

    首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...

  6. Apache Shiro 开源权限框架

    在 Web 项目中应用 Apache Shiro 开源权限框架 Apache Shiro 是功能强大并且容易集成的开源权限框架,它能够完成认证.授权.加密.会话管理等功能.认证和授权为权限控制的核心, ...

  7. 各大开源rpc 框架 比较

    各大开源rpc 框架 比较   1. 前言 随着现在互联网行业的发展,越来越多的框架.中间件.容器等开源技术不断地涌现,更好地来服务于业务,解决实现业务的问题.然而面对众多的技术选择,我们要如何甄别出 ...

  8. 分享一实战性开源MVC框架<Linux、Windows跨平台开发so easy>

    一.引子   开源地址 https://github.com/564064202/Moon.Mvc 欢迎加入开发 .NET Core微软还在发力,但作为商用还有一段距离,很多开发库尚不能用于.NET ...

  9. PHP框架中的日志系统

    现在在一家公司做PHP后台开发程序猿(我们组没有前端,做活动时会做前端的东西),刚开始到公司的时候花2个周赶出了一个前端加后台的活动(记得当时做不出来周末加了两天班...),到现在过去4个多月了,可以 ...

随机推荐

  1. IOS开发教程--怎样使用点9图片

    事先准备一张图片: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA== ...

  2. RecyclerView的点击事件

    RecyclerView 一.简单介绍 这个是谷歌官方出的控件.使我们能够很easy的做出列表装的一个控件,当然recyclerview的功能不止这些,它还能够做出瀑布流的效果,这是一个很强大的控件, ...

  3. javaScript实现日历控件

    近期学习js.闲来无事就写了个简单的日历控件.不知道别人是怎么实现的.纯粹自己想法写的, 写的不好 ,但能够起到抛砖引玉的作用. 先来看效果. watermark/2/text/aHR0cDovL2J ...

  4. poj--1985--Cow Marathon(树的直径)

    Cow Marathon Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 4424   Accepted: 2214 Case ...

  5. EOJ 3000 ROT13加密和解密

    应用 ROT13 到一段文字上仅仅只需要检查字母顺序并取代它在 13 位之后的对应字母,有需要超过时则重新绕回 26 英文字母开头即可.A 换成 N.B 换成 O.依此类推到 M 换成 Z,然后串行反 ...

  6. 剑指offer——02替换空格(Python3)

    思路:Python列表中实现字符串的替换,涉及到频繁的插入操作,在数据结构中线性表分为顺序表和链表,顺序表的适合频繁的查询,链表适合频繁的插入和删除.综上所述,本题使用链表来实现. 我们从字符串的后面 ...

  7. OC中的类扩展

    类扩展 是在原有类的基础扩展一个新的属性和对象方法 但是方法的实现还是要写在原有的声明中,不然是不会被访问到的 类扩展可以扩展在新的头文件中,然后在主函数中导入. 利用类扩展可以变相的实现属性的私有化 ...

  8. Hua Wei 机试题目三---2014

    一.根据对应规则进行翻译输出 描述:已知有如下的对应规则: ,则输入任意个正整数,输出经过规则翻译以后对应的结果. 例如:输入:1234:输出bcde. 题目很简单,我觉得需要注意的问题就是对于大整数 ...

  9. mobiscroll插件的基本使用方法

    前一阵子接触到了mobiscroll插件,用在移动端的日期选择上,感觉倍棒,于是便敲了一个小案例,与大家一起分享分享 <!DOCTYPE html> <html lang=" ...

  10. Hibernate框架学习(三)——实体规则、对象状态、一级缓存

    一.Hibernate中的实体规则 1.实体类创建的注意事项 1)持久化类提供无参数构造,因为在Hibernate的底层需要使用反射生成类的实例. 2)成员变量私有,提供公有的get和set方法,需提 ...