Java中List的add方法不检查List中是否含有已加入项
List中添加的是引用,而且不检查是否已经加入list
这也就意味着:如果管理一堆循环使用的对象,对list的存放操作不应该是链式而应该是栈式,不然的话随着链的推进实际上可供使用的对象会被挤入垃圾堆然后被回收掉,列表看起来大小变化不大但是实际上只剩不多的实际引用对象,而对该对象的任何操作(如设置可见属性或者设置值)都会给list的使用带来不可估量的影响
而且每次添加入列表,如果对于列表中的元素有唯一性要求的话(一般都有吧)需要检查是否已经存在于列表中。
下附测试代码:
fucker b = new fucker();
fucker a = new fucker();
a.Oops();
b.Oops();
List<fucker> lbs = new ArrayList<>();
for (int i= 0;i<10;i++) {
lbs.add(a);
lbs.add(b);
}
a.fuck();
for (int i=0;i<10;i++) {
lbs.get(0).fuck();
lbs.remove(lbs.get(0));
lbs.get(0).fuck();
lbs.remove(lbs.get(0));
}
fucker:
public class fucker {
private int value=0;
public void fuck() {
System.out.println("OOOO!");
System.out.println(value);
value = 0;
}
public void Oops() {
value = 1;
System.out.println("Changed!");
}
}
其实一般来说这种对象应该是不用管理的,但是师兄不信任java的垃圾回收机制,而我坚信他setVisible(View.Gone)便以为view不存在的方法会对开发带了破坏性的阻碍,所以折中选择了一下……