Nik*_*vin 8 java logging android buffer
默认情况下,登录android平台的控制台输出的字符数量有限.大约等于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);
}
}
}
Run Code Online (Sandbox Code Playgroud)
这个问题有更好的解决方案吗?
小智 9
执行大输出(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));
}
Run Code Online (Sandbox Code Playgroud)