Java中的每个类基本上都继承自Object,标准容器类自然也不例外。因此容器类都有toString()方法,并且重写了该方法,使得它生成的String结果能够表达容器本身,以及容器所包含的对象。
例如ArrayList.toString(),它会遍历ArrayList中包含的所有对象,调用每个元素上的toString()方法:
public class Person { private int age; private String name; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Person(int age, String name) { super(); this.age = age; this.name = name; } @Override public String toString() { return "Person [age=" + age + ", name=" + name + "]"; } public static void main(String[] args) { ArrayList<Person> persons = new ArrayList<>(); Person p1 = new Person(10, "张三"); Person p2 = new Person(12, "李四"); persons.add(p1); persons.add(p2); //(1)和(2)输出结果相同 System.out.println(persons);//(1) System.out.println(persons.toString());//(2) } }
输出结果为:
[Person [age=10, name=张三], Person [age=12, name=李四]] [Person [age=10, name=张三], Person [age=12, name=李四]]
如果你希望toString()方法打印出对象的内存地址,也许你会考虑使用this关键字:
public class Person { private int age; private String name; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Person(int age, String name) { super(); this.age = age; this.name = name; } @Override public String toString() { return "Person address:"+this; } public static void main(String[] args) { ArrayList<Person> persons = new ArrayList<>(); Person p1 = new Person(10, "张三"); Person p2 = new Person(12, "李四"); persons.add(p1); persons.add(p2); System.out.println(persons);//(1) System.out.println(persons.toString());//(2) } }
当你创建了Person对象,并将其打印出来的时候,你会得到一串非常长的异常。如果你将该Person对象存入一个ArrayList中,然后打印该ArrayList,你也会得到同样的异常。其实,当如下代码运行时:
"Person address:" + this
这里发生了自动类型转换,有Person类型转换成String类型。因为编译器看到一个String对象后面跟着一个"+",而再后面的对象不是String,于是编译器试着将this转换成一个String。它怎么转换呢?正是通过调用this上的toString()方法,于是就发生了递归调用。
如果你真的想要打印出对象的内存地址,应该调用Object.toString()方法,这才是负责此任务的方法。所以,不能使用this,而是应该调用super.toString()方法。
即把上面的toString()方法改为:
@Override public String toString() { return "Person address:" + super.toString(); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
我需要解码一个递归编码为count后跟substring的字符串 给定一个编码字符串,任务是对其进行解码。字符串的编码模式如下所示。 示例: 输入:str[]=“1[b]”输出:b 输入:str[]="2[ab]输出:abab 输入:str[]=“2[a2[b]”输出:ABB 输入:str[]="3[b2[ca]]"输出:bcacabcacabcaca 下面是我试图实现的代码。我只知道它可以用两个
本文向大家介绍java递归法求字符串逆序,包括了java递归法求字符串逆序的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了java递归法求字符串逆序的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的java程序设计有所帮助。
我试图编写一个方法,使用递归打印字符串的所有排列。现在,我有这样的代码: 它打印出正确的结果,但我试图在不使用循环的情况下解决它,包括第4行中的循环。可能吗?如果是这样,你会如何解决?非常感谢。 我试图添加第三个名为index的参数,并在第5行的递归调用中写入index 1,但没有成功。我认为添加第三个参数是个好主意,我只是不知道如何使用它。
我看到了这篇文章,它非常努力地解释了打印所有字符串的递归解决方案。 但当我们开始弹出堆栈时,我仍然无法得到部分。例如,递归一直进行到,在这里,基大小写遇到,它打印。但现在发生了什么?我们从函数调用堆栈弹出。我们用这个做什么等等? 谁能帮我解释一下吗? 另外,我需要一些关于时间复杂度的指示。不像完全的计算而是一些暗示。
我需要一些帮助在Java:我有一个函数签名,我不能改变,我的函数需要递归和返回字符串数组没有任何选项添加到签名。 这是我的签名: 该函数在TRIE结构中查找相似的单词,在它们之间有K个字母变化的差异。 例如-在单词“bike”和k=2的TRIE中,该函数将返回一个(包含nice和nine)。 我不是在寻找解决方案,只是为了一个返回字符串数组的方法。 **我用我收到的签名编写了一个函数作为包装器,但
问题内容: 我正在尝试查找字符串中字母的首次出现。例如,苹果中的p应该返回1。这是我拥有的: 它似乎似乎没有返回正确的值。 问题答案: 您的尝试很好,但是还不够。这是基于您的正确实现: 您的尝试存在两个问题: 在这一部分中,您已经找到了角色,因此正确的做法是停止递归,但您仍在继续。 在最后一个return语句中,您需要在递归调用中加1(如果最终找到了该字符),作为累加总索引号的一种方式。