如何在logcat中看到一个用于android的数组

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.vString不是File[].Java严格执行参数类型.

更新:

您可以轻松地将包含File对象的信息转换为String对象.所有的Java对象实现toString(),这如果我没有记错返回的组合ClassNameaddress对象的所在.但是,这通常不包含有用的信息.所以你需要自己定义转换.

现在要转换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)

它更简单,可以生成更清晰的日志消息,并且更容易理解程序员正在发生的事情.