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

日志打印不全原因

因为安卓内核对日志打印长度有要求, 不得超过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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在开发中我们常常会打Log来调试程序,但有时候打印的信息长度非常长,比如我们想打Log查看接口返回的json数据,...
    JxYoung阅读 20,099评论 7 14
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,635评论 25 709
  • 博客原文链接 Android百大框架排行榜(转) 说明: 无聊写一篇笔记式文章. 精力有限,很多错误之处,受时间与...
    码农朱同学阅读 2,799评论 0 27
  • 周六带两个女儿去天津科技馆一日游,累得周日早晨说啥也起不来床。婆婆每天是我家起床最晚的,周日因为要去检查身体,早早...
    心理咨询师云舒阅读 544评论 2 1
  • 最幸福的就是我了 今天天气真好 阳光明媚 孩子们在院子里玩的好开心 自己心情也不错 感赏好天气 好心情 感赏老公下...
    幸福魔法师阅读 237评论 0 0