开源TT框架上的日志类
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框架上的日志类的更多相关文章
- 字节开源RPC框架Kitex的日志库klog源码解读
前言 这篇文章将着重于分析字节跳动开源的RPC框架Kitex的日志库klog的源码,通过对比Go原生日志库log的实现,探究其作出的改进. 为了平滑学习曲线,我写下了这篇分析Go原生log库的文章,希 ...
- 高性能日志类KLog(已开源代码)
项目开源地址:https://github.com/ihambert/KLog 上回介绍了超简易日志类,但他有诸多的局限性,注定了不能作为一个网站的日志类. 那什么样的日志类才能用于网站呢.首先来假 ...
- 如何优雅的阅读 GitHub 上开源 js 框架和库的源码
如何优雅的阅读 GitHub 上开源 js 框架和库的源码 step 先总后分,即先了解一下啊框架的大体架构,又一个全局的认识,在选择某些和感兴趣的部分,仔细阅读,各个击破: 带着问题阅读,用到了什么 ...
- python3+selenium框架设计03-封装日志类
首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...
- python3+requests库框架设计02-封装日志类
首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...
- Apache Shiro 开源权限框架
在 Web 项目中应用 Apache Shiro 开源权限框架 Apache Shiro 是功能强大并且容易集成的开源权限框架,它能够完成认证.授权.加密.会话管理等功能.认证和授权为权限控制的核心, ...
- 各大开源rpc 框架 比较
各大开源rpc 框架 比较 1. 前言 随着现在互联网行业的发展,越来越多的框架.中间件.容器等开源技术不断地涌现,更好地来服务于业务,解决实现业务的问题.然而面对众多的技术选择,我们要如何甄别出 ...
- 分享一实战性开源MVC框架<Linux、Windows跨平台开发so easy>
一.引子 开源地址 https://github.com/564064202/Moon.Mvc 欢迎加入开发 .NET Core微软还在发力,但作为商用还有一段距离,很多开发库尚不能用于.NET ...
- PHP框架中的日志系统
现在在一家公司做PHP后台开发程序猿(我们组没有前端,做活动时会做前端的东西),刚开始到公司的时候花2个周赶出了一个前端加后台的活动(记得当时做不出来周末加了两天班...),到现在过去4个多月了,可以 ...
随机推荐
- cocos2dx项目创建
射击类游戏文档 作者:浙江传媒学院 新媒体 张勇 1>编译环境 首先我们先去cocos2dx官网上下载cocos2dx最新版本号 http://www.cocos2d-x.org/ 我下载的 ...
- iOS开发-文件管理之多的是你不知道的事(一)
郝萌主倾心贡献.尊重作者的劳动成果,请勿转载. 假设文章对您有所帮助,欢迎给作者捐赠,支持郝萌主,捐赠数额任意,重在心意^_^ 我要捐赠: 点击捐赠 Cocos2d-X源代码下载:点我传送 游戏官方下 ...
- HDU 5654 xiaoxin and his watermelon candy 离线树状数组
xiaoxin and his watermelon candy Problem Description During his six grade summer vacation, xiaoxin g ...
- Android安全攻防战,反编译与混淆技术全然解析(下)
转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/50451259 在上一篇文章其中,我们学习了Android程序反编译方面的知识,包括 ...
- 卷积操作中的矩阵乘法(gemm)—— 为什么矩阵乘法是深度学习的核心所在
1. 全连接 k 个输入: n 个神经元: 每个神经元都会学到一组权值向量,以和输入进行内积运算: n 个输出: 2. 卷积 卷积操作对于高维(多个平面)的输入,单个卷积核的深度应和输入的深度(dep ...
- Statspack的使用
Statspack是Oracle 8i以上提供的一个非常好的性能监控与诊断工具,基本上全部包含了BSTAT/ESTAT的功能,更多的信息可以参考附带文档$ORACLE_HOME/rdbms/admin ...
- Regexp-Utils:基本
ylbtech-Regexp-Utils:基本 1.返回顶部 1. /** * 管理 */ var utils = { hostUrl: "http://localhost:8023&quo ...
- HD-ACM算法专攻系列(15)——Quoit Design
问题描述: 源码: 经典问题——最近邻问题,标准解法 #include"iostream" #include"algorithm" #include" ...
- SpringBoot(九) ElasticSearch 全文检索
ElasticSearch ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用 ...
- vue中使用UEditor编辑器 -- 2
1:下载ueditor下来,放在vue项目中的static文件夹下 2:创建ueditor编辑界面 3:椰~~~~~此时已经可以使用了 但是你会发现 (黑人脸)what the fuck??? ...