Bad*_*ari 9 java arrays android logcat
我想在我的logcat中记录像数组这样的原始数据,所以我知道输出是什么.让我们说我有一个数组......就像那样:
File[] mp3List = ...
Log.v("test", mp3List);
Run Code Online (Sandbox Code Playgroud)
为什么我不能只将数组记录到控制台?我该怎么做?
Jiv*_*ngs 14
您无法记录该数组,因为它只是一个Object.LogCat不知道如何处理它或以你想要的方式显示它.
如果每个File对象都有一个toString()方法,它显示了您可以使用的信息:
Log.v(Arrays.toString(mp3List));
否则,您必须将自己的String连接到日志:
StringBuilder sb = new StringBuilder();
for(File f : mp3List) {
sb.append(f.getName());
}
Log.v(sb.toString());
Run Code Online (Sandbox Code Playgroud)
sla*_*ton 10
为什么这不工作的原因很简单,因为的第二个参数Log.v是String不是File[].Java严格执行参数类型.
更新:
您可以轻松地将包含File对象的信息转换为String对象.所有的Java对象实现toString(),这如果我没有记错返回的组合ClassName和address对象的所在.但是,这通常不包含有用的信息.所以你需要自己定义转换.
现在要转换File[]到String更复杂,因为当你调用一个阵列上的方法,它工作的数组对象上,而不是一个数组的成员(其中包含我怀疑你关心的信息).因此,调用mp3List.toString()将返回描述数组对象的单个字符串,而不是数组中包含的信息.
所以你可能想写一个像这样的方法:
String fileArrayToString(File[] f){
String output = "";
String delimiter = "\n" // Can be new line \n tab \t etc...
for (int i=0; i<f.length; i++)
{
output = output + f[i].getPath() + delimiter;
}
return output;
}
Run Code Online (Sandbox Code Playgroud)
然后调用如下所示进行日志调用:
Log.v("MyTag", fileArraytoString(mp3List);
Run Code Online (Sandbox Code Playgroud)
然而,这可能很难阅读.
我个人会这样做:
for (int i=0; i<mp3List.legnth; i++)
Log.v("MyTag", Integer.toString(i) + ":" + mp3List[i].getPath());
Run Code Online (Sandbox Code Playgroud)
它更简单,可以生成更清晰的日志消息,并且更容易理解程序员正在发生的事情.
| 归档时间: |
|
| 查看次数: |
13098 次 |
| 最近记录: |