java中出现的一个递归的问题

本文深入探讨了Java中容器类toString方法的递归调用问题,解析了错误原因,并提供了正确的解决方案。文章指出,在重写toString方法时,直接使用this会导致无限递归,正确的做法是调用super.toString()。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

例子

我们知道Java中每一个类都是继承自Object,容器类也不例外。Object有toString方法,那么容器类也就拥有。先看下面一个例子。作用是:创建一个容器类,并通过toString方法打印出容器内部的子类。

package com.test;

import java.util.ArrayList;
import java.util.List;

public class StringDiGui {

	public String toString(){
		return "StringDiGui的调用类的地址是"+this+"\n";
	}

	public static void main(String[] args) {
		List<StringDiGui> list =new ArrayList<StringDiGui>();
		for(int i=0;i<5;i++){
			list.add(new StringDiGui());
		}
		System.out.println(list);
	}

}

错误

在这里我们重写了toString方法,并在for循环中创建了五个这样的类,最后调用打印,但是2这样后台会报错,先看一下控制台的出错信息:

这个出错信息是超级多的,而且可以说是永远都在出错。这是因为出现了递归调用的问题。

原因

那么问题出现在哪呢?就在这一行

return "StringDiGui的调用类的地址是"+this+"\n";

这里的this出现了递归调用。在这里编译器会将this自动转换为String。但是this不是一个String,怎么办呢?此时this就会自己调用toString方法。在新的toString方法中又出现了this,那么编译器有想要把这个this转化为String,此时this又继续调用toString方法。就这样循环往复成为了死循环的递归调用。

解决

如何去解决呢?在这里我们不应该调用当前对象的this,而是super.toString方法。也就是把这一行代码换成。

return "StringDiGui的调用类的地址是"+super.toString()+"\n";

正确结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值