Android日志系统第三方库------Logger 源码分析
2017-08-28 20:54
423 查看
Android日志系统第三方库——Logger 源码分析
在前面了解Logger的使用方法http://blog.csdn.net/chenqianleo/article/details/77461446,想这个第三方库的实现应该很简单,看了源码后代码量很小仅有1000多行代码,1000多行代码就可以实现这么漂亮好用的Logger工具,代码对我来说还是值得阅读的,代码下载请从官方git下载https://github.com/orhanobut/logger。下面先放一张自己的图和官方的图,第一次画uml不知道怎么用,哪里画错了请指教 :)自己总结的
官方自带的
阅读感悟
1.使用接口编程,面向抽象编程,不要面向实现编程;从上面两幅图可以看出,主框架主要有接口构成,所以不管是选择直接使用控制台打印Log还是存储到disk都可以直接继承相应的接口去实现相应的功能
2.作者构造精致的打印界面
3.针对json和xml转换为string,针对json看是否是json数组选择合适的方法
4.得到当前线程的堆栈信息值得学习,在app出现ANR时可以得到堆栈信息
5.具体的代码注释等信息可以查看我的githttps://git.oschina.net/qianlilo/LoggerDiSanFangKuYuanMaYueDu,仅仅下载那十几个源码部分就可以了
XMl字符串格式化输出
public static void main(String[] args) throws TransformerException { //DATA_XML是符合xml格式输入的字符串 Source xmlInput = new StreamSource(new StringReader(DATA_XML)); StreamResult xmlOutput = new StreamResult(new StringWriter()); Transformer transformer = TransformerFactory.newInstance().newTransformer(); transformer.setOutputProperty(OutputKeys.INDENT , "yes"); transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "2"); transformer.transform(xmlInput , xmlOutput); System.out.println(xmlOutput.getWriter().toString()); }
打印堆栈信息
public class StackTraceDemo { public static void main(String[] args) { a(); } private static void a(){ b(); } private static void b() { c(); } private static void c() { StackTraceElement[] trace = Thread.currentThread().getStackTrace(); for(int i = trace.length-1 ; i >= 0 ;i--){ StringBuilder builder = new StringBuilder(); builder.append(" ") .append(trace[i].getClassName()) .append(".") .append(trace[i].getMethodName()) .append(" ") .append(" (") .append(trace[i].getFileName()) .append(":") .append(trace[i].getLineNumber()) .append(")"); System.out.println(builder.toString()); } } }
相关文章推荐
- Android 系统源码情景分析读书笔记(2)----Logger 日志系统
- Android日志系统第三方库------Logger
- Android源码解析之日志系统驱动程序Logger
- Android日志系统驱动程序Logger源代码分析
- Android日志系统驱动程序Logger源代码分析
- android日志系统源码分析
- Android日志系统驱动程序Logger源代码分析 (转)
- Android日志系统驱动程序Logger源代码分析
- Android日志系统驱动程序Logger源代码分析
- Android Logger 日志框架源码分析
- Android日志系统驱动程序Logger源代码分析
- Android日志系统Logcat源代码简要分析
- Android日志系统Logcat源代码简要分析
- Android日志系统分析之开篇
- Android系统原理与源码分析(1):利用Java反射技术阻止通过按钮关闭对话框
- Android日志系统Logcat源代码简要分析
- 【北京讲座】Android系统Framework层源码分析(2011.09.24)
- Android应用程序框架层和系统运行库层日志系统源代码分析
- Android日志系统驱动程序Logger源代码分析
- velocity源码分析:初始化之日志系统