Thinking in java第二版中166页的一段关于array初始化的代码:
class A{int i;}
public class VarArgs{
static void f(Object[] x){
for(int i=0;i<x.length;i++)
System.out.println(x[i]);
}
public static void main(String[] args){
f(new Object[]{
new Integer(47),new VarArgs(),
new Float(3.14),new Double(11.11)});
f(new Object[]{"one","two","three"});
f(new Object[]{new A(),new A(),new A()});
}
}
运行结果为:
47
VarArgs@1ba34f2
3.14
11.11
one
two
three
A@13f5d07
A@f4a24a
A@cac268
===============
我对此代码的理解:
java使用new objectname()创建了该对象的引用。每一个对象都从Object继承一个toString()方法。当使用System.out.println输出一个引用的时候实际上调用了该对象的toString()方法。对于没有toString方法的类,println则输出该实例的“地址”。
在打印的时候,如果你在你的代码中没有重载toString()方法,那么java将自动调用object的toString()方法,而object的toString()方法一般就是打印某个对象的地址,所以诸如这里的class A,由于你没有重载toString()方法,所以调用object的toString()方法,打印了地址。而对于某些类,诸如这里的Double对象,由于java已经在Double重载了toString(),虽然你没有再次重载,但它还是会根据Double里已经存在的toString()方法打印了
danceflash对此代码中输出地址的不同理解
关于调用object的toString()方法这一点上完全同意
但是要注意的是:
打印出来的"A@13f5d07"并非他的"地址",而是对象的所属类以及该对象的哈希值
以下是Object类的toString()方法的代码:
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
其中:
getClass().getName()返回对象所属类的类名
hashCode()返回该对象的哈希值
Integer.toHexString(hashCode())将对象的哈希值用16进制表示
因此最后得到了这样的结果:A@13f5d07
==================================
下面给出另外一个例子:
public class B
{
public String toString()
{
return "This is a ";
}
}
public class A
{
public static void main(String[] args)
{
System.out.println(new B());
}
}
输出结果:This is a
理解:因为在B中已经声明了toString方法,实际是对toString方法进行了重载了,此时System.out.println(object)会自动调用该object的toString方法输出。
java中任何class都是默认从Object扩展而来,都有一个toString()方法,System.out.println(object)会默认调用这个object的toString方法,如果在class里面,重写了这个toString()方法,也就是说那么输出的时候,调用的toString方法就是class中所定义的了。
其实,System.out.println()的参数就是string ,他会把其中的参数转换为string类型,给你重写tostring方法,所以当把new b()转化成string时,将调用tostring 函数,而此时调用的就是你定义的函数。
注:因为想到什么写什么,所以比较乱,见谅。。^_^