- import java.util.*;
- public class Test {
- public static void main(String args[]) {
- Set<Short> s = new HashSet<Short>();
- for (Short i = 0; i < 100; i++) {
- s.add(i);
- if(i>0){
- s.remove(i - 1);
- }
- }
- System.out.println(s.size());
- }
- }
运行结果为100
分析:
1 Set的remove调用的是删除一个对象remove(Object)
2 Short 和 Integer 进行比较时,是肯定不等的,虽然他们的数值相等。
因为在equals时,先判断对象类型instanceof,他们类型不同,自然不等。
boolean remove(Object o)
如果 set 中存在指定的元素,则将其移除(可选操作)。更确切地讲,如果此 set 中包含满足 (o==null ? e==null : o.equals(e)) 的元素 e,则移除它。如果此 set 包含指定的元素(或者此 set 由于调用而发生更改),则返回 true(一旦调用返回,则此 set 不再包含指定的元素)。
指定者:
接口 Collection <E> 中的 remove
参数:
o - 从 set 中移除的对象(如果存在)
返回:
如果此 set 包含指定的对象,则返回 true
抛出:
ClassCastException - 如果指定元素的类型与此 set 不兼容(可选)
NullPointerException - 如果指定的元素为 null,并且此 set 不允许 null 元素(可选)
UnsupportedOperationException - 如果此 set 不支持 remove 操作
remove的参数是Object,而lz的程序里写的是int值,所以没有删除掉。
本文通过一个Java示例展示了Set数据结构的工作原理,特别是HashSet的行为。代码演示了如何添加和尝试移除元素,最终解释了为何预期移除操作未生效的原因。
2905

被折叠的 条评论
为什么被折叠?



