在Java中,数组不会重写toString(),因此如果您尝试直接打印一个,则会得到数组的className+“@”+hashCode的十六进制,如Object.toString()所定义:

int[] intArray = new int[] {1, 2, 3, 4, 5};
System.out.println(intArray); // Prints something like '[I@3343c8b3'

但通常情况下,我们会想要更像[1,2,3,4,5]的东西。最简单的方法是什么?以下是一些输入和输出示例:

// Array of primitives:
int[] intArray = new int[] {1, 2, 3, 4, 5};
// Output: [1, 2, 3, 4, 5]

// Array of object references:
String[] strArray = new String[] {"John", "Mary", "Bob"};
// Output: [John, Mary, Bob]

当前回答

要添加到所有答案中,还可以选择将对象打印为JSON字符串。

使用Jackson:

ObjectWriter ow = new ObjectMapper().writer().withDefaultPrettyPrinter();
System.out.println(ow.writeValueAsString(anyArray));

使用Gson:

Gson gson = new Gson();
System.out.println(gson.toJson(anyArray));

其他回答

这里有一个可能的打印功能:

  public static void printArray (int [] array){
        System.out.print("{ ");
        for (int i = 0; i < array.length; i++){
            System.out.print("[" + array[i] + "] ");
        }
        System.out.print("}");
    }

例如,如果main是这样的

public static void main (String [] args){
    int [] array = {1, 2, 3, 4};
    printArray(array);
}

输出将是{[1][2][3][4]}

从Java5开始,您可以对数组中的数组使用Arrays.toString(arr)或Arrays.deepToString(arr)。注意,Object[]版本对数组中的每个对象调用.toString()。输出甚至按照您要求的方式进行装饰。

示例:

简单阵列:String[]数组=新String[]{“John”,“Mary”,“Bob”};System.out.println(数组.toString(数组));输出:[约翰、玛丽、鲍勃]嵌套数组:String[][]deepArray=新String[][]{{“John”,“Mary”},{“Alice”,“Bob”}};//产生不希望的输出:System.out.println(Arrays.toString(deepArray));//给出所需输出:System.out.println(Array.deepToString(deepArray));输出:[[Ljava.lang.String;@106d69c,[Ljava.lang.String;@52e922][[约翰,玛丽],[爱丽丝,鲍勃]]双阵列:double[]doubleArray={7.0,9.0,5.0,1.0,3.0};System.out.println(Arrays.toString(doubleArray));输出:[7.0, 9.0, 5.0, 1.0, 3.0 ]int数组:int[]intArray={7,9,5,1,3};System.out.println(数组.toString(intArray));输出:[7, 9, 5, 1, 3 ]

我最近在Vanilla#Java上看到了这篇文章。编写Arrays.toString(arr);,然后导入java.util.Arrays;总是

请注意,无论如何,这不是永久性的修复。只是一个可以使调试更简单的黑客。

打印一个数组直接给出内部表示和hashCode。现在,所有类都将Object作为父类型。那么,为什么不破解Object.toString()呢?如果不进行修改,Object类如下所示:

public String toString() {
    return getClass().getName() + "@" + Integer.toHexString(hashCode());
}

如果更改为:

public String toString() {
    if (this instanceof boolean[])
        return Arrays.toString((boolean[]) this);
    if (this instanceof byte[])
        return Arrays.toString((byte[]) this);
    if (this instanceof short[])
        return Arrays.toString((short[]) this);
    if (this instanceof char[])
        return Arrays.toString((char[]) this);
    if (this instanceof int[])
        return Arrays.toString((int[]) this);
    if (this instanceof long[])
        return Arrays.toString((long[]) this);
    if (this instanceof float[])
        return Arrays.toString((float[]) this);
    if (this instanceof double[])
        return Arrays.toString((double[]) this);
    if (this instanceof Object[])
        return Arrays.deepToString((Object[]) this);
    return getClass().getName() + "@" + Integer.toHexString(hashCode());
}

通过向命令行添加以下内容,可以简单地将这个修改后的类添加到类路径中:-Xbootclasspath/p:target/classes。

现在,随着自Java5以来deepToString(..)的可用性,toString(.)可以很容易地更改为deepToString(..),以添加对包含其他数组的数组的支持。

我发现这是一个非常有用的黑客,如果Java可以简单地添加它,那就太好了。我理解拥有非常大的数组可能存在的问题,因为字符串表示可能会有问题。可能会传递类似System.out或PrintWriter这样的事件。

使用Arrays类。它有多个实用程序方法,其toString()被重写为以人类可读的方式显示数组元素。数组.toString(arr)

不过,很高兴知道,关于“总是先检查标准库”,我从来不会偶然发现Arrays.toString(myarray)的技巧

--因为我正专注于myarray的类型,看看如何做到这一点。我不想重复这个过程:我想要一个简单的调用,让它看起来像我在Eclipse调试器中看到的那样,而myarray.toString()并没有这么做。

import java.util.Arrays;
.
.
.
System.out.println( Arrays.toString( myarray ) );