日志打印不全原因
因为安卓内核对日志打印长度有要求, 不得超过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
如果有更好的方法, 例如可以修改内核中日志打印的长度限制, 希望大家可以一起分享!!!
网友评论