java-- 集合

集合

概念:

Java 集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组。

Java 集合可分为 Collection 和 Map 两种体系

  • Collection接口:
Set:元素无序、不可重复的集合 ---类似高中的“集合”

List:元素有序,可重复的集合  ---”动态”数组

set接口

特征:

1. Set接口是Collection的子接口,set接口没有提供额外的方法
2. Set 集合不允许包含相同的元素,如果试把两个相同的元素加入同一个 Set 集合中,则添加操作失败。
3. Set 判断两个对象是否相同不是使用 == 运算符,而是根据 equals 方法
Set实现类之一:HashSet
1. HashSet 是 Set 接口的典型实现,大多数时候使用 Set 集合时都使用这个实现类。
2. HashSet 按 Hash 算法来存储集合中的元素,因此具有很好的存取和查找性能。
3. 不能保证元素的排列顺序
4. HashSet 不是线程安全的
5. 集合元素可以是 null
6. 当向 HashSet 集合中存入一个元素时,HashSet 会调用该对象的 hashCode() 方法来得到该对象的 hashCode 值,然后根据 hashCode 值决定该对象在 HashSet 中的存储位置
7. HashSet 集合判断两个元素相等的标准:两个对象通过 hashCode() 方法比较相等,并且两个对象的 equals() 方法返回值也相等。
8. 如果两个元素的 equals() 方法返回 true,但它们的 hashCode() 返回值不相等,hashSet 将会把它们存储在不同的位置,但依然可以添加成功。
9. 对于存放在Set容器中的对象,对应的类一定要重写equals()和hashCode(Object obj)方法,以实现对象相等规则。

重写 hashCode() 方法的基本原则:

在程序运行时,同一个对象多次调用 hashCode() 方法应该返回相同的值
当两个对象的 equals() 方法比较返回 true 时,这两个对象的 hashCode() 方法的返回值也应相等
对象中用作 equals() 方法比较的 Field,都应该用来计算 hashCode 值
Set实现类之二:LinkedHashSet
1. LinkedHashSet 是 HashSet 的子类
2. LinkedHashSet 根据元素的 hashCode 值来决定元素的存储位置,但它同时使用链表维护元素的次序,这使得元素看起来是以插入顺序保存的。
3. LinkedHashSet插入性能略低于 HashSet,但在迭代访问 Set 里的全部元素时有很好的性能。
4. LinkedHashSet 不允许集合元素重复。
Set实现类之三:TreeSet
1. TreeSet 是 SortedSet 接口的实现类,TreeSet 可以确保集合元素处于排序状态。
2. TreeSet 两种排序方法:自然排序和定制排序。默认情况下,TreeSet 采用自然排序。

涉及到TreeSet 排序:

  • 自然排序
1. 自然排序:TreeSet 会调用集合元素的 compareTo(Object obj) 方法来比较元素之间的大小关系,然后将集合元素按升序排列.

2. 如果试图把一个对象添加到 TreeSet 时,则该对象的类必须实现 Comparable 接口。

3. 实现 Comparable 的类必须实现 compareTo(Object obj) 方法,两个对象即通过 compareTo(Object obj) 方法的返回值来比较大小

4. 向 TreeSet 中添加元素时,只有第一个元素无须比较compareTo()方法,后面添加的所有元素都会调用compareTo()方法进行比较。
5. 因为只有相同类的两个实例才会比较大小,所以向 TreeSet 中添加的应该是同一个类的对象
6. 对于 TreeSet 集合而言,它判断两个对象是否相等的唯一标准是:两个对象通过 compareTo(Object obj) 方法比较返回值
7. 当需要把一个对象放入 TreeSet 中,重写该对象对应的 equals() 方法时,应保证该方法与 compareTo(Object obj) 方法有一致的结果:如果两个对象通过 equals() 方法比较返回 true,则通过 compareTo(Object obj) 方法比较应返回 0
  • 定制排序
1. TreeSet的自然排序是根据集合元素的大小,进行元素升序排列。如果需要定制排序,比如降序排列,可通过Comparator接口的帮助。需要重写compare(T o1,T o2)方法。
2. 利用int compare(T o1,T o2)方法,比较o1和o2的大小:如果方法返回正整数,则表示o1大于o2;如果返回0,表示相等;返回负整数,表示o1小于o2。
3. 要实现定制排序,需要将实现Comparator接口的实例作为形参传递给TreeSet的构造器。
4. 此时,仍然只能向TreeSet中添加类型相同的对象。否则发生ClassCastException异常。
5. 使用定制排序判断两个元素相等的标准是:通过Comparator比较两个元素返回了0。

list接口

特征:

1. Java中数组用来存储数据的局限性
2. List集合类中元素有序、且可重复,集合中的每个元素都有其对应的顺序索引。
3. List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素
4. JDK API中List接口的实现类常用的有:ArrayList、LinkedList和Vector。
List实现类之一: ArrayList
1. ArrayList 是 List 接口的典型实现类
2. 本质上,ArrayList是对象引用的一个变长数组
3. ArrayList 是线程不安全的,而 Vector 是线程安全的,即使为保证 List 集合线程安全,也不推荐使用Vector
4. Arrays.asList(…) 方法返回的 List 集合既不是 ArrayList 实例,也不是 Vector 实例。 Arrays.asList(…)  返回值是一个固定长度的 List 集合
List实现类之二:LinkedList
对于频繁的插入或删除元素的操作,建议使用LinkedList类,效率较高
List 实现类之三:Vector
1. Vector 是一个古老的集合,JDK1.0就有了。大多数操作与ArrayList相同,区别之处在于Vector是线程安全的。

2. 在各种list中,最好把ArrayList作为缺省选择。当插入、删除频繁时,使用LinkedList;Vector总是比ArrayList慢,所以尽量避免使用。
  • Map接口
具有映射关系“key-value对”的集合 ---类似于高中的“函数” y = f(x)   (x1,y1) (x2,y2)

特征:

1. Map与Collection并列存在。用于保存具有映射关系的数据:Key-Value
2. Map 中的 key 和  value 都可以是任何引用类型的数据
3. Map 中的 key 用Set来存放,不允许重复,即同一个 Map 对象所对应的类,须重写hashCode()和equals()方法。
4. 常用String类作为Map的“键”。
5. key 和 value 之间存在单向一对一关系,即通过指定的 key 总能找到唯一的、确定的 value。

Map接口常用方法

  • 添加删除操作
Object put(Object key,Object value)
Object remove(Object key)
void putAll(Map t)
void clear()
  • 元视图操作的方法
Set keySet()
Collection values()
Set entrySet()
  • 元素查询的操作:
Object get(Object key)
boolean containsKey(Object key)
boolean containsValue(Object value)
int size()
boolean isEmpty()
boolean equals(Object obj)
Map实现类之一:HashMap
1. Map接口的常用实现类:HashMap、TreeMap和Properties。
2. HashMap是 Map 接口使用频率最高的实现类。
3. 允许使用null键和null值,与HashSet一样,不保证映射的顺序。
4. HashMap 判断两个 key 相等的标准是:两个 key 通过 equals() 方法返回 true,hashCode 值也相等。
5. HashMap 判断两个 value相等的标准是:两个 value 通过 equals() 方法返回 true
Map实现类之二:LinkedHashMap
1. LinkedHashMap 是 HashMap 的子类
2. 与LinkedHashSet类似,LinkedHashMap 可以维护 Map 的迭代顺序:迭代顺序与 Key-Value 对的插入顺序一致
Map实现类之三:TreeMap
1. TreeMap存储 Key-Value 对时,需要根据 key-value 对进行排序。TreeMap 可以保证所有的 Key-Value 对处于有序状态。
2. TreeMap 的 Key 的排序:
    - 自然排序:TreeMap 的所有的 Key 必须实现 Comparable 接口,而且所有的 Key 应该是同一个类的对象,否则将会抛出 ClasssCastException
    - 定制排序:创建 TreeMap 时,传入一个 Comparator 对象,该对象负责对 TreeMap 中的所有 key 进行排序。此时不需要 Map 的 Key 实现 Comparable 接口

3. TreeMap判断两个key相等的标准:两个key通过compareTo()方法或者compare()方法返回04. 若使用自定义类作为TreeMap的key,所属类需要重写equals()和hashCode()方法,且equals()方法返回true时,compareTo()方法应返回0
Map实现类之四:Hashtable
1. Hashtable是个古老的 Map 实现类,线程安全。
2. 与HashMap不同,Hashtable 不允许使用 null 作为 key 和 value
3. 与HashMap一样,Hashtable 也不能保证其中 Key-Value 对的顺序
4. Hashtable判断两个key相等、两个value相等的标准,与hashMap一致。
Map实现类之五:Properties
1. Properties 类是 Hashtable 的子类,该对象用于处理属性文件
2. 由于属性文件里的 key、value 都是字符串类型,所以 Properties 里的 key 和 value 都是字符串类型
3. 存取数据时,建议使用setProperty(String key,String value)方法和getProperty(String key)方法

Collection接口继承树

这里写图片描述

Collection 接口是 List、Set 和 Queue 接口的父接口,该接口里定义的方法既可用于操作 Set 集合,也可用于操作 List 和 Queue 集合。

Map接口继承树

Map

使用 Iterator 接口遍历集合元素

所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了Iterator接口的对象。
Iterator 仅用于遍历集合,Iterator 本身并不提供承装对象的能力。如果需要创建 Iterator 对象,则必须有一个被迭代的集合。

Iterator iterator = coll.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}

Iterator接口的方法

这里写图片描述

在调用it.next()方法之前必须要调用it.hasNext()进行检测。若不调用,且下一条记录无效,直接调用it.next()会抛出NoSuchElementException异常。

使用 foreach 循环遍历集合元素

这里写图片描述

操作集合的工具类Collections

  • 查找、替换

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值