ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

集合(collection)

2022-02-23 10:31:06  阅读:140  来源: 互联网

标签:Object 实现 元素 接口 int collection 集合


一、简述

集合是一个容器,用来存储一组对象(元素类型可以不同、集合长度可变、空间不固定)。

1️⃣Java 集合操作相关的接口和类定义在java.util包中。
2️⃣Collection 接口存储的是一组无序,不唯一的对象。
3️⃣Collections 工具类提供对集合的系列操作。
4️⃣List 接口存储一组有序,不唯一的对象。List 接口的典型实现类有 ArrayList(基于数组实现), LinkedList(基于链表实现)
5️⃣Set 接口存储一组无序, 唯一的对象。Set 接口的典型实现类有 HashSet(哈希表实现),TreeSet(排序实现)。
6️⃣Map 接口存储从键(key)到值(value)的映射。Map 接口的典型实现类有 HashMap,TreeMap。

二、List 接口

1️⃣常用方法

add(Object)
add(int, Object)
remove(int)
remove(Object)
contains(Object)
get(int)
size()
clear()

2️⃣遍历方式

1.传统下标方式

for(int i=0; i<list.size();i++){}

2.forEach 循环

for(Object object : list){}

3.迭代器

Iterator it = list.iterator();
while(it.hasNext()){
Object object = it.next();
}

3️⃣两种典型实现的比较

ArrayList:基于数组实现,遍历元素/随机访问元素效率较高,但插入/删除元素效率较低。
容量增长规律:每次增长现有容量的一半+1

LinkedList:基于链表实现,遍历元素/随机访问元素效率较低,但插入/删除元素效率较高。

4️⃣特有的方法:

addFirst()
addLast()
removeFirst()
getFrist()

注意:不能用 List 类型的变量来调用这些方法。

5️⃣Vector:基于数组实现,但它是线程安全的,所以它的效率低于ArrayList。

三、iterator 与 iterable

1️⃣Iterator 是迭代器,负责具体的循环迭代工作。
2️⃣Iterable 表示可迭代的,Collection 接口继承了 iterable 接口,只要实现了 Iterable 接口的集合类都是可以被迭代的。
3️⃣Iterable 接口中定义了 iterator(),它返回 Iterator 实例。

四、泛型集合

ArrayList 在添加元素时,接受 Object 类型的参数,这里发生了装箱(向上转型为 Object)操作;在调用 get() 获取元素时,返回的是 Object 类型的元素,这里可能需要拆箱(Object 向下转型为实际的类型)操作;但实际上这个元素可能是 String、Account…这就造成了装拆箱的性能损耗及类型转换时可能发生的错误。Java5 后,通过泛型解决了这个问题。

注意:装箱前的原始类型是什么,拆箱后就只能是什么。Java5 后,各种集合类型的定义都是泛型的。泛型集合的优势:

  1. 编译期类型检查,更安全。
  2. 不拆箱不装箱,性能提高。

五、Set 接口

1️⃣Set 接口不允许重复元素,判断重复的依据是 equals + hashCode。

2️⃣HashSet 是基于 HashMap 的实现。

3️⃣TreeSet 是基于 TreeMap 的实现,它要求元素要实现 Comparable 接口或者在构造 TreeSet 时,传入一个 Comparator。

六、Comparator 与 Comparable

这两个接口都是用于对象间比较大小的。

Comparable 接口定义的是对象自身和别的同类对象之间的比较过程。 其用法:

class XXX implements Comparable{
    public int compareTo(XXX another){
    }
}

Comparator 接口定义的是两个同类对象之间的比较过程。 其用法:

new Comparator(){
    public int compare(XXX o1, XXX o2){
    }
}

相比而言,Comparator 要更灵活。

七、Map 接口

Map 用于存储键值对。Key 不能重复,一旦重复,覆盖原有的 Value。典型实现类: HashMap、TreeMap。

Map常用方法:

put(K,V)
get(K)
remove(K)
size()
containsKey(K)
containsValue(V)
keySet()
values()
entrySet()

标签:Object,实现,元素,接口,int,collection,集合
来源: https://blog.csdn.net/ChineseSoftware/article/details/123083953

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有