当前位置: 首页 > 知识库问答 >
问题:

覆盖toString方法?[重复]

翟棋
2023-03-14

我这样做对吗?我生成了toString()。

@Override
public String toString()
{
return "Auto [exampleOne=" + exampleOne + ", exampleTwo=" + exampleTwo + ", exampleThree=" + exampleThree ", getexampleOne()=" + getexampleOne() + ", getexampleTwo()=" + getexampleTwo() + ", getexampleThree()=" + getexampleThree() + ", toString()=" + super.toString() + "]";
}

共有2个答案

越高峻
2023-03-14

Java规范不使用toString()作为smth的逻辑。并且不严格它。所以开发人员可以自由地自己实现这个方法。我认为有几个建议:

  • 它应该是简单的
  • 它应该易于计算
  • 它不应该抛出异常
  • IDE用于在调试器中对对象进行分类,因此最好在这里的一行中打印出最重要的值

我不建议使用此方法作为用户的输出字符串或smth。像这样。您应该为格式化的输出字符串创建一个单独的方法。

长孙德惠
2023-03-14

是的,这会覆盖toString()方法,当将此类的对象隐式转换为字符串时,将调用该方法。显示的内容取决于函数返回的字符串。

请注意,Override已经在帮助您解决这个问题。它告诉编译器“嘿,我想重写一个函数,请检查,如果真的这样做了”(参见这里)。

 类似资料:
  • 问题内容: 我想为Java中的ArrayList拥有toString()方法的自己的实现。但是,即使我将这样的toString()添加到包含ArrayList的类中,我也无法正常工作。 当我这样调用ArrayList时,我仍然会获得默认表示形式。我想念什么吗? 问题答案: 你应该做类似的事情 并将列表作为参数传递给。您 可以从 技术上扩展(使用匿名类或具体类)并实现自己,但这在这里似乎是不必要的。

  • 问题内容: 这个问题来自一个作业。我必须在创建循环链接列表的类中重写toString()方法,而实际上我的toString()方法效果很好,它通过了我所有的测试。因此,我的项目是自动分级的,显然它不是100%赞成我的方法。所以我的问题是:有没有更好的方法来编写此toString()方法,这样会更有效? 如果我需要详细说明类结构,以便更有意义,请告诉我。 问题答案: 使用StringBuilder。

  • 操作步骤: 菜单栏: Code —> Generate —> toString() 右键菜单: Generate —> toString() 快捷键: Mac: command + N Windows\/Linux: Alt + Insert —> toString()

  • 在这个特定的示例中,我扩展了

  • 问题内容: 我已经尝试解决了几个小时,但是找不到有效的答案。 为了完整起见,我在下面发布了整个代码。如果不重写toString方法,则将获得对象哈希码的表示形式。 我尝试使用以下内容: 但是,这似乎无济于事,因为我仍然获得了对哈希码的引用。我知道这是因为我没有正确覆盖toString方法;包含@Override批注时出现错误,但据我所知。 我查看了其他一些回答,这些回答说,在列表/集合的情况下,重

  • 问题内容: 我需要方法方面的帮助,这非常令人讨厌。我尝试在线查找,因为那是一个正在搞砸的地方,即使在那里,它也“找不到2号Kid构造函数”,我什至会做其他事情,但它不起作用。好了,所以这是我的代码: 好的,所以我上面的toString(我知道,我的第三个参数已关闭,应该是String)已关闭。如果我在第三件事中硬编码一个值,它就会变成麻烦,并说找不到它(上面)。那么如何获取日期并将其拆分呢? 调用