Android日志系统第三方库------Logger 源码分析

本文深入分析了Android第三方日志库Logger的源码,该库代码量少但功能强大。通过接口编程实现了灵活的日志输出方式,既可控制台打印,也可存储到磁盘。同时,库中包含了精致的日志格式,智能处理JSON和XML,以及获取当前线程堆栈信息等功能。阅读源码带来了关于面向抽象编程、日志格式设计和错误排查等方面的启示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android日志系统第三方库——Logger 源码分析


在前面了解Logger的使用方法http://blog.youkuaiyun.com/chenqianleo/article/details/77461446,想这个第三方库的实现应该很简单,看了源码后代码量很小仅有1000多行代码,1000多行代码就可以实现这么漂亮好用的Logger工具,代码对我来说还是值得阅读的,代码下载请从官方git下载https://github.com/orhanobut/logger。下面先放一张自己的图和官方的图,第一次画uml不知道怎么用,哪里画错了请指教 :)

自己总结的
http://i.imgur.com/VeWahnt.png

官方自带的
https://i-blog.csdnimg.cn/blog_migrate/a37d01f57c7d6e9d7d729fea03398dad.png

阅读感悟

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());
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值