List list = new ArrayList();
背景: List如上的写法,那么取出来的值,默认是Object'类型,而泛型List<T>,这个地方T可以是任意的,比如string
正文:
当我们写一段代码:
Book类:
public class Book {
public String bookname;
public String personName;
public int kk;
public Book(String bookname, String persionName, int kk) {
this.bookname = bookname;
this.personName = persionName;
this.kk = kk;
}
}
Main类:
package com.haspdu.test;
import java.util.ArrayList;
import java.util.List;
public class List_03 {
public static void main(String[] args){
List list = new ArrayList();
list.add(new Book("红楼梦","曹雪芹",100));
list.add(new Book("三国演义","吴承恩",1012));
list.add(new Book("西游记","施耐庵",1013));
//遍历
for(Object b: list){
System.out.println(b);
}
}
}
那么这时会出现如下结果:
com.haspdu.test.Book@1b6d3586
com.haspdu.test.Book@4554617c
com.haspdu.test.Book@74a14482
com.haspdu.test.Book@1540e19d
那么这是为什么呢?
因为这里输出的是Objiect的地址,也是一个字符串,以[包名.]类名@对象在内存中的地址的16进制表示来返回对象的字符串表示形式,所以这里就会显示这个。
那么怎么可以输出值呢?
因为所有的类的根类就是Object,当输出一个对象时,如果一个子类没有重写根类的这个toString方法,就会先调用Object类的toString方法将对象转换成一个字符串,然后输出这个字符串
所以我们加上这个override就好了,加在Book类中
public class Book {
public String bookname;
public String personName;
public int kk;
public Book(String bookname, String persionName, int kk) {
this.bookname = bookname;
this.personName = persionName;
this.kk = kk;
}
@Override
public String toString() {
return ""+
"bookname='" + bookname + '\'' +
", personName='" + personName + '\'' +
", kk=" + kk;
}
}
这时结果就对了
bookname='yyy', personName='777', kk=111
bookname='红楼梦', personName='曹雪芹', kk=100
bookname='三国演义', personName='吴承恩', kk=1012
bookname='西游记', personName='施耐庵', kk=1013