日志打印不全原因
因為安卓內(nèi)核對日志打印長度有要求, 不得超過4KB, 這樣日志太長了之后會導(dǎo)致Logcat分段打印, 這樣就會造成部分日志缺失.我們復(fù)制日志使用HiJson格式化后, 可能會報錯.
安卓內(nèi)核中的原碼在下面這個鏈接中有介紹, 大家可以了解一下.
http://0xcc0xcd.com/p/books/978-7-121-18108-5/c461.php
大家需要注意的是這是安卓內(nèi)核的代碼, 并不是studio決定的, 所以沒有辦法輕易修改這個限制.
解決日志打印不全辦法
網(wǎng)上如下這種解決辦法 ,但并不實用
如下方法雖然是能全部打印出來,但打印出來后沒法直接復(fù)制, 因為Logcat每次打印日志時, 還會在日志前面有一段系統(tǒng)的標(biāo)識(打印時間, tag等等), 我們所需要的是將日志直接復(fù)制,然后放到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 ) {// 循環(huán)分段打印日志
String logContent = msg.substring(0, segmentSize );
msg = msg.replace(logContent, "");
Log.e(tag, logContent);
}
Log.e(tag, msg);// 打印剩余日志
}
}
}
終極解決辦法
使用chrome調(diào)試android, 在這里面攔截日志.
使用瀏覽器來攔截返回數(shù)據(jù), 就可以拿到完整的日志信息.
但必須提醒大家的是, 在一般情況, 盡量不要使用這個框架來調(diào)試, 尤其是有數(shù)據(jù)庫緩存的時候, 這是因為它會拖慢運(yùn)行速度.
如下圖:
image.png
調(diào)試框架github地址: <meta charset="utf-8">
https://github.com/facebook/stetho
使用方法: <meta charset="utf-8">
http://www.reibang.com/p/6c4b57810388
如果有更好的方法, 例如可以修改內(nèi)核中日志打印的長度限制, 希望大家可以一起分享!!!