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不存在的方法會對開發帶了破壞性的阻礙,所以折中選擇了一下……