CGBTN2107-DAY14总结复习
Posted 程序媛 泡泡
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CGBTN2107-DAY14总结复习相关的知识,希望对你有一定的参考价值。
DAY14 复习
1. Collection接口
是集合层次的根接口,学习抽象父级的公共方法
Collection集合方法总结
单个集合的操作:
boolean add(E e) 将指定元素添加到集合中
void clear() 清空集合
boolean contains(Object o) 判断本集合是否包含指定的元素
boolean equals(Object o) 比较集合对象与参数对象o是否相等
int hashCode() 返回本集合的哈希码值。
boolean isEmpty() 判断本集合是否为空
boolean remove(Object o) 从本集合中移除指定元素o
int size() 返回本集合中元素的个数
Object[] toArray() 将本集合转为数组
集合间的操作:
boolean addAll(Collection<> c) 将c集合中的所有元素添加到本集合中
boolean containsAll(Collection<> c) 判断本集合是否包含c集合的所有元素
boolean removeAll(Collection<> c) 移除本集合中属于参数集合c的所有元素
boolean retainAll(Collection<> c) 保留本集合与参数集合c的公共元素
集合的迭代:
Iterator iterator() 返回本集合的迭代器
2. List接口
List接口的特点
- List集合是有下标的
- List集合是有顺序的
- List集合可以存放重复的数据
List集合方法总结
单个集合间的操作
void add(int index, E element) 在集合的指定下标index处插入指定元素element
E get(int index) 返回本集合中指定下标index处的元素
E remove(int index) 移除本集合中指定下标index处的元素
E set(int index, E element) 用参数元素element替换集合中指定下标index处的元素
int indexOf(Object o) 判断指定元素o在本集合中第一次出现的下标,如果不存在,返回-1
int lastIndexOf(Object o) 判断指定元素o在本集合中最后一次出现的下标,如果不存在,返回-1
List subList(int fromIndex, int toIndex) 截取子集合,包含formidex处的元素,不包含toIndex处的元素
集合间的操作与集合的迭代
boolean addAll(int index, Collection<> c) 将参数集合c中的所有元素,插入到本集合中指定的下标index处
ListIterator listIterator() 返回此列表元素的迭代器,这个是List自己的,不太常用,可以逆序迭代
3.List接口的两个常用实现类
ArrayList的特点:
- 底层的数据结构是数组,内存空间是连续的
- 元素有下标,通常可以根据下标进行操作
- 增删操作比较慢,查询操作比较快【数据量大时】
LinkedList的特点:
- 底层的数据结构是链表,内存空间是不连续的
- 元素有下标,但是通常首尾节点操作比较多
- 增删操作比较快,查询操作比较慢【数据量大时】
注意:LinkedList查询慢也不是都慢,首尾操作还是比较快的
简单方法:
void addFirst(E e) 添加首元素
void addLast(E e) 添加尾元素
E removeFirst() 删除首元素
E removeLast() 删除尾元素
E getFirst() 获取首元素
E getLast() 获取尾元素
E element() 获取首元素
功能一致但是名字不太好记的方法:
boolean offer(E e) 添加尾元素
boolean offerFirst(E e) 添加首元素
boolean offerLast(E e) 添加尾元素
E peek() 获取首元素
E peekFirst() 获取首元素
E peekLast() 获取尾元素
E poll() 返回并移除头元素
E pollFirst() 返回并移除头元素
E pollLast() 返回并移除尾元素
4. Map接口
Map接口的特点
- map集合的结构是:键值对、KEY与VALUE、Map.Entry<K,V>的映射关系
- map中key值不允许重复,如果重复,对应的value会被覆盖
- map中的映射关系是无序的
- map没有自己的迭代器,所以迭代时通常需要转成set集合来迭代
Map集合方法总结
简单方法:
void clear() 清空集合
boolean equals(Object o) 判断集合对象与参数o是否相等
int hashCode() 返回本集合的哈希码值
boolean isEmpty() 判断集合是否为空
int size() 返回本集合中键值对的个数
map单个集合间的操作
boolean containsKey(Object key) 判断map中是否包含指定的key
boolean containsValue(Object value) 判断map中是否包含指定的value
V get(Object key) 根据指定的key返回对应的value,如果不存在,返回null
V remove(Object key) 删除本集合中参数key对应的键值对
V put(K key, V value) 向集合中添加映射关系(键值对)
void putAll(Map<> m) 向本集合中添加m集合的所有映射关系(键值对)
map的迭代
Collection values() 把本map中的Value值取出放入一个Collection中并返回这个Collection
Set keySet() 把本map中的Key值取出放入一个Set集合中并返回这个Set集合
Set<Map.Entry<K,V>> entrySet()
把本map中的每一对KV都看成是一个Entry,把所有的Entry取出放入一个Set集合中并返回这个Set集合
5. Set接口
Set接口的特点
- set集合没有重复的元素
- set集合的元素是无序的
- set集合可以存null值,并且null最多有一个
- 我们自定义对象如果想去重,需要在自定义类中添加重写的equals()与hashCode()
集合学习的方法
学习父级的公共方法,学习子类的创建方式,学习各种集合的特点
- 关于List大多都是与下标有关的操作
- 关于Set通常都是去重的操作
- 关于map通常都是映射关系,也就是键值对
- API要常练习,方法互相之间没有任何关系,用哪个,查哪个
以上是关于CGBTN2107-DAY14总结复习的主要内容,如果未能解决你的问题,请参考以下文章