集合 --- HashSet
来源:互联网 发布:苹果微信加附近人软件 编辑:程序博客网 时间:2024/06/13 07:51
import java.util.*;/*|--Set:元素是无序(存入和取出的顺序不一定一致),元素不可以重复。、 |--HashSet:底层数据结构是哈希表。是线程不安全的。不同步。 HashSet是如何保证元素唯一性的呢? 是通过元素的两个方法,hashCode和equals来完成。 如果元素的HashCode值相同,才会判断equals是否为true。 如果元素的hashcode值不同,不会调用equals。 注意,对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法。 |--TreeSet:Set集合的功能和Collection是一致的。*/class HashSetDemo { public static void sop(Object obj) { System.out.println(obj); } public static void main(String[] args) { HashSet hs = new HashSet(); sop(hs.add("java01")); sop(hs.add("java01")); hs.add("java02"); hs.add("java03"); hs.add("java03"); hs.add("java04"); Iterator it = hs.iterator(); while(it.hasNext()) { sop(it.next()); } }}**练习**import java.util.*;/*往hashSet集合中存入自定对象姓名和年龄相同为同一个人,重复元素。*/class HashSetTest { public static void sop(Object obj) { System.out.println(obj); } public static void main(String[] args) { HashSet hs = new HashSet(); hs.add(new Person("a1",11)); hs.add(new Person("a2",12)); hs.add(new Person("a3",13));// hs.add(new Person("a2",12));// hs.add(new Person("a4",14)); //sop("a1:"+hs.contains(new Person("a2",12)));// hs.remove(new Person("a4",13)); Iterator it = hs.iterator(); while(it.hasNext()) { Person p = (Person)it.next(); sop(p.getName()+"::"+p.getAge()); } }}class Person{ private String name; private int age; Person(String name,int age) { this.name = name; this.age = age; } public int hashCode() { System.out.println(this.name+"....hashCode"); return name.hashCode()+age*37; } public boolean equals(Object obj) { if(!(obj instanceof Person)) return false; Person p = (Person)obj; System.out.println(this.name+"...equals.."+p.name); return this.name.equals(p.name) && this.age == p.age; } public String getName() { return name; } public int getAge() { return age; }}/**/
0 0
- HashSet集合
- HashSet集合
- HashSet集合
- HashSet集合
- 集合 --- HashSet
- HashSet集合
- HashSet集合
- HashSet集合
- 集合-HashSet
- 集合框架 HashSet集合
- 集合框架--HashSet集合
- HashSet存储自定义集合
- 集合类 hashset
- Set集合之HashSet
- 【集合】HashSet类
- Java 集合框架-HashSet
- java基础--HashSet集合
- 集合框架(HashSet)
- cocos2d-x 遍历assets下资源
- dubbo 常见的问题bug梳理
- NSSearchPathForDirectoriesInDomains用法,关于沙盒路径
- 微信手Q分享js定制
- Disable HTML a links in different browser
- 集合 --- HashSet
- 后缀数组 DA(倍增)算法求 SA[N] 与 Rank[N] (时间O(NlogN),空间O(N))
- thrift的概念理解
- /etc/init.d/rcs分析
- Static关键字作用是什么?
- linux sed
- 第一次比赛(续)
- CSS3属性之Multiple backgrounds
- Design中NavigationView MenuItem选中字体Icon颜色