Android中Logcat日志打印不全解决办法

2018-02-05  本文已影响0人  ttkx0915

日志打印不全原因

因为安卓内核对日志打印长度有要求, 不得超过4KB, 这样日志太长了之后会导致Logcat分段打印, 这样就会造成部分日志缺失.我们复制日志使用HiJson格式化后, 可能会报错.
安卓内核中的原码在下面这个链接中有介绍, 大家可以了解一下.
http://0xcc0xcd.com/p/books/978-7-121-18108-5/c461.php

大家需要注意的是这是安卓内核的代码, 并不是studio决定的, 所以没有办法轻易修改这个限制.

解决日志打印不全办法

网上如下这种解决办法 ,但并不实用

如下方法虽然是能全部打印出来,但打印出来后没法直接复制, 因为Logcat每次打印日志时, 还会在日志前面有一段系统的标识(打印时间, tag等等), 我们所需要的是将日志直接复制,然后放到HiJson等工具中直接格式化,如此一来,太麻烦, 也不实用.

public class LogUtil {
    /**
     * 截断输出日志
     * @param msg
     */
    public static void e(String tag, String msg) {
        if (tag == null || tag.length() == 0 
                || msg == null || msg.length() == 0)
            return;

        int segmentSize = 3 * 1024;
        long length = msg.length();
        if (length <= segmentSize ) {// 长度小于等于限制直接打印
             Log.e(tag, msg);
        }else {
            while (msg.length() > segmentSize ) {// 循环分段打印日志
                String logContent = msg.substring(0, segmentSize );
                msg = msg.replace(logContent, "");
                Log.e(tag, logContent);
            }
            Log.e(tag, msg);// 打印剩余日志    
        }
    }
}

终极解决办法

使用chrome调试android, 在这里面拦截日志.
使用浏览器来拦截返回数据, 就可以拿到完整的日志信息.
但必须提醒大家的是, 在一般情况, 尽量不要使用这个框架来调试, 尤其是有数据库缓存的时候, 这是因为它会拖慢运行速度.
如下图:


image.png

调试框架github地址: <meta charset="utf-8">

https://github.com/facebook/stetho

使用方法: <meta charset="utf-8">

http://www.jianshu.com/p/6c4b57810388

如果有更好的方法, 例如可以修改内核中日志打印的长度限制, 希望大家可以一起分享!!!

上一篇 下一篇

猜你喜欢

热点阅读