1 **在码代码时,发现一个问题:**使用
list<object> list=new Arraylist<object>();
list.add(object);
出现之前添加的元素被最后的元素覆盖。
类似于:
ArrayList<Object> list = new ArrayList<Object>();
Object obj;
for (int i = 10; i > 0; i--) {
objt.set(i);
list.add(obj);
/*会发现list存放的obj的数都是1*/
之所以将 Objec new在循环的外面,就是想节省空间,(不用在循环中每次循环斗殴需要new一个对象)。但是忘了考虑到:
ArrayList集合里存的是一个对象的引用。当我们改变obj时,因为ArrayList.add的是 obj的引用,之前的元素都指向了同一个对象 obj,所以在改变obj时,之前添加的也会随之改变。,
解决方法:
将 Objec new在循环的里面。
for (int i = 10; i > 0; i--) {
Object obj=new Object();
objt.set(i);
list.add(obj);
2 还有一种情况:
涉及静态变量
public Class Student {
private static String id;
private static String name;
public Student(String id, String name) {
this.id = id;
this.name = name;
}
}
如果我们这样将元素添加到list中:
ArrayList<Student> list = new ArrayList<Student>();
Student s1 = new Student("1", "小山");
Student s2 = new Student("2", "小康");
//
list.add(s1);
list.add(s2);
//如果输出两个对象的话你会发现都是小康
//或者你像这样
ArrayList<Student> list = new ArrayList<Student>();
for (int i = 10; i > 0; i--) {
list.add(new Student(i, "name"));
}
//你会发现输出所有对象,他们的id都是1
每次add()的虽然是不同的对象,但是结果还是被覆盖了,这是为什么呢?
原因:
static(Student 类中)就是这个修饰符,
让修饰的属性变为静态,
意味着该类的所有对象共享同一个属性
所以尽管集合里存的是不同的对象,但是对象的属性还是同一个值
借鉴:https://blog.csdn.net/zouhaipeng/article/details/53160124
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)