今天看了Java编程思想,关于Arrays.toString()与Arrays.deepToString()用法。
public static void main(String[] args){
Integer[][] a;
a=new Integer[3][];
for(int i=0;i<a.length;i++){
a[i]=new Integer[3];
for(int j=0;j<a[i].length;j++){
a[i][j]=i*j;
}
System.out.println(Arrays.deepToString(a));
System.out.println(Arrays.toString(a));
}
}
结果:
[[0, 0, 0], null, null]
[[Ljava.lang.Integer;@1540e19d, null, null]
[[0, 0, 0], [0, 1, 2], null]
[[Ljava.lang.Integer;@1540e19d, [Ljava.lang.Integer;@677327b6, null]
[[0, 0, 0], [0, 1, 2], [0, 2, 4]]
[[Ljava.lang.Integer;@1540e19d, [Ljava.lang.Integer;@677327b6, [Ljava.lang.Integer;@14ae5a5]
其中各位应该已经看到了,使用toString()返回的是类型加地址。而deepToString()返回这是一个数值,但是为什么在这两种方法会有差异性呢??
下面我就介绍一下关于这两个方法的介绍:
Arrays.toString
,这个方法实现了String.valueof()的功能
public static String toString(Object[] a)
{ if (a == null) return "null"; int iMax = a.length - 1; if (iMax == -1) return "[]";
StringBuilder b = new StringBuilder();
b.append('[');
for (int i = 0; ; i++) {
b.append(String.valueOf(a[i])); if (i == iMax) return b.append(']').toString();
b.append(", ");
}
}
调用了String.valueof()这个方法,这个方法我在前几天博客中已经写了,最终调用的是:
public String toString()
{ return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
所以最后输入就是一串奇怪的值。
但是对于deepToString方法,一个深层次调用toString方法。
public static String deepToString(Object[] a) {
if (a == null) return "null"; int bufLen = 20 * a.length;
if (a.length != 0 && bufLen <= 0)
bufLen = Integer.MAX_VALUE;
StringBuilder buf = new StringBuilder(bufLen);
deepToString(a, buf, new HashSet<Object[]>());
return buf.toString();
}
private static void deepToString(Object[] a, StringBuilder buf,
Set<Object[]> dejaVu) {
if (a == null) {
buf.append("null"); return;
} int iMax = a.length - 1; if (iMax == -1) {
buf.append("[]"); return;
}
dejaVu.add(a);
buf.append('[');
for (int i = 0; ; i++) {
Object element = a[i];
if (element == null) {
buf.append("null");
} else {
Class<?> eClass = element.getClass();
if (eClass.isArray()) {
if (eClass == byte[].class)
buf.append(toString((byte[]) element)); else if (eClass == short[].class)
buf.append(toString((short[]) element)); else if (eClass == int[].class)
buf.append(toString((int[]) element)); else if (eClass == long[].class)
buf.append(toString((long[]) element)); else if (eClass == char[].class)
buf.append(toString((char[]) element)); else if (eClass == float[].class)
buf.append(toString((float[]) element)); else if (eClass == double[].class)
buf.append(toString((double[]) element)); else if (eClass == boolean[].class)
buf.append(toString((boolean[]) element)); else { // element is an array of object references if (dejaVu.contains(element))
buf.append("[...]"); else deepToString((Object[])element, buf, dejaVu);
}
} else { // element is non-null and not an array buf.append(element.toString());
}
} if (i == iMax) break;
buf.append(", ");
}
buf.append(']');
dejaVu.remove(a);
}
在这里面,我们可以看到我们可以根据数组的类型,使用图toString()判断的时候,直接把数组进行判断,由于String.class中没有关于数组判断的方法,所以跳转到Object.class中进行toString()方法输入,但是deepToString则先把他拆分为字符,然后进行逐一的类型判断,最后把相应类型的传入String.class中的相关方法,进行一个输出。随便获取一个例子:
public static String toString(byte[] a) { if (a == null) return "null"; int iMax = a.length - 1; if (iMax == -1) return "[]";
StringBuilder b = new StringBuilder();
b.append('['); for (int i = 0; ; i++) {
b.append(a[i]); if (i == iMax) return b.append(']').toString();
b.append(", ");
}
}
有这部分我们可以看出,我们使用StringBuilder来拼接数组。在deepToString()方法中,我们直接操作的是数组里面的内容。