对于 Android 平台上的默认 Log,控制台输出的字符数量有限。大约等于 3000 多一点。因此,如果消息长度超过 3000 个字符,则不会在屏幕上显示。
我还没有找到比这更好的解决方案:
public class Log {
private static int mode = android.util.Log.INFO;
public static void e(String tag, String msg, Throwable tr) {
if ((mode & android.util.Log.ERROR) <= 0) return;
android.util.Log.e(tag, msg, tr);
}
public static void e(String tag, String msg) {
if ((mode & android.util.Log.ERROR) <= 0) return;
android.util.Log.e(tag, msg);
}
public static void w(String tag, String msg) {
if ((mode & android.util.Log.WARN) <= 0) return;
android.util.Log.w(tag, msg);
}
public static void i(String tag, String msg) {
if ((mode & android.util.Log.INFO) <= 0) return;
android.util.Log.i(tag, msg);
}
public static void d(String tag, String msg) {
if ((mode & android.util.Log.DEBUG) <= 0) return;
int length = msg.length();
int kind = 3000;
if (length >= kind) {
int count = length / kind;
int u = length % kind;
int i = 0;
for (i = 0; i < count; ++i) {
int start = i * kind;
int end = start + kind;
android.util.Log.d(tag, msg.substring(start, end));
}
if (u != 0) {
int start = length - u;
int end = start + u;
android.util.Log.d(tag, msg.substring(start, end));
}
} else {
android.util.Log.d(tag, msg);
}
}
}
这个问题有更好的解决办法吗?
进行大型输出(JSON 等)时 1024 个字符限制的解决方法
是做一个简单的 for 循环,将它们记录在块中。
它可能不像您的那么复杂,但它很容易看,并且不会使代码变得过于混乱。
String json = data.toString();
int length = json.length();
for(int i=0; i<length; i+=1024)
{
if(i+1024<length)
Log.d("JSON OUTPUT", json.substring(i, i+1024));
else
Log.d("JSON OUTPUT", json.substring(i, length));
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)