tostring方法的陷进

最近看到一道很有趣的面试题:谈谈tostring()方法有什么陷阱,一开始没什么思路,后来翻看了《Thinking in java》这本书在string这章找到了答案。

        tostring方法介绍:

返回该对象的字符串表示。通常,toString()方法会返回一个“以文本方式表示”此对象的字符串。结果应是一个简明但易于读懂的信息表达式。建议所有子类都重写此方法。

     该方法返回一个字符串,该字符串由类名(对象是该类的一个实例)、at 标记符“@”和此对象哈希码的无符号十六进制表示组成。换句话说,该方法返回一个字符串,默认代码如下:

public String toString() {
    return getClass().getName() + "@" + Integer.toHexString(hashCode());  // 也就是返回类名以及该对象的十六进制hashcode 
}

因为它是Object里面已经有了的方法,而所有类都是继承Object,所以“所有对象都有这个方法”。
它通常只是为了方便输出,比如System.out.println(xx),括号里面的“xx”如果不是String类型的话,就自动调用xx的toString()方法,同样的,对于"+"号连接的字符串和对象,默认会将对象转化为字符串,也会调用该对象的toString方法。
总而言之,它只是sun公司开发java的时候为了方便所有类的字符串操作而特意加入的一个方法


陷阱:

package test160118;

public class TestToString {
    public static void main(String[] args) {
        TestToString t1 = new TestToString();
        System.out.println(t1.toString());
    }
    
    @Override
    public String toString() {
        return "TestToString"+this;
    }
}


分析

  • 代码重写了toString方法

  • 重写的方法使用了"+"连接字符串和this

  • 在调用toString()方法时,进行"TestToString"+this时,会将this这个对象转化为String,同样要调用到this的toString()方法,于是产生了无穷递归的陷阱。




你可能感兴趣的:(Java)