android 部分log不打印不出来,Android中Logcat日志打印不全解决办法

日志打印不全原因

因为安卓内核对日志打印长度有要求, 不得超过4KB, 这样日志太长了之后会导致Logcat分段打印, 这样就会造成部分日志缺失.我们复制日志使用HiJson格式化后, 可能会报错.

安卓内核中的原码在下面这个链接中有介绍, 大家可以了解一下.

http://0xcc0xcd.com/p/books/978-7-121-18108-5/c461.php

29c3a5f151b3

大家需要注意的是这是安卓内核的代码, 并不是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, 在这里面拦截日志.

使用浏览器来拦截返回数据, 就可以拿到完整的日志信息.

但必须提醒大家的是, 在一般情况, 尽量不要使用这个框架来调试, 尤其是有数据库缓存的时候, 这是因为它会拖慢运行速度.

如下图:

29c3a5f151b3

image.png

调试框架github地址:

使用方法:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值