-
set接口特点:
- 存储任意Object元素
- 无序,无下标,元素内容不可以重
-
方法:
- 继承父接口Collection中的所有方法
-
遍历:
-
有两种遍历方法,foreach遍历和迭代遍历
forEach遍历
-
Set<Object> set = new HashSet<Object>(); for (Object obj: set) { if(obj instanceof Integer){ int aa= (Integer)obj; }else if(obj instanceof String){ String aa = (String)obj } } |
迭代遍历
|
-
实现类:
-
HashSet
为了保证hashset中自定义类型的对象,内容相同 拒绝加入集合,解决方案:
第一步:覆盖hashCode方法
确保相同的对象 返回 相同的hashCode值。
为了提高效率 尽量保证只有相同的对象 才拿到相同的hashCode值。
通常,所有属性进行拼接形成int值,如果是引用类型 则调用其hashCode方法。
-
@Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + age; result = prime * result + ((clazz == null) ? 0 : clazz.hashCode()); result = prime * result + ((name == null) ? 0 : name.hashCode()); return result; } |
第二步:覆盖equals方法
对象的hashCode值相同时,才会调用equals方法,如果内容相同返回true,代表当前对象是重复对象,应该 被拒绝加入集合。
@Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; Student other = (Student) obj; if (age != other.age) return false; if (clazz == null) { if (other.clazz != null) return false; } else if (!clazz.equals(other.clazz)) return false; if (name == null) { if (other.name != null) return false; } else if (!name.equals(other.name)) return false; return true; } |
-
hashset的特点:
-
底层使用数据结构的hash算法实现的,因此具有很好的存取,查找的性能。
-
hashSet是线程不安全,所以它相对于线程安全的更快一些。
-
hashSet值可以为null。
-
不存在顺序
-
-
TreeSet
实现了SortedSet接口(是Set的子接口)
注意:集合元素如果是自定义类型,该类型必须实现java.lang.Comparable接口。
-
TreeSet的特点:
- 底层使用数据结构红黑树算法进行维护的,因此它的性能相对hashset来说,更差一些,因为它内部会自动进行排序操作。
- TreeSet也是线程不安全
- 排序分为自然排序和定制排序,自然排序是treeset内部会对add进来的值进行自动排序,定制排序可以对排序的条件进行限制。
-
总结:
- 以上写了一些set集合的基本用法,以及set集合的常用实现类
- 注意 hashset, treeset都是线程不安全的,所以要保证线程安全,要使用collections下面的syschronizedSet来进行同步操作。