资讯专栏INFORMATION COLUMN

CGBTN2110-DAY15总结复习

dackel / 2284人阅读

摘要:复习接口接口的特点集合是有下标的集合是有顺序的集合可以存放重复的数据集合方法总结单个集合间的操作在集合的指定下标处插入指定元素返回本集合中指定下标处的元素移除本集合中指定下标处的元素用参数元素替换集合中指定下标处的元素

DAY15 复习

1. List接口

1.1 List接口的特点

  1. List集合是有下标的
  2. List集合是有顺序的
  3. List集合可以存放重复的数据

1.2 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自己的,不太常用,可以逆序迭代

1.3 ArrayList的特点:

1.List接口的实现类
2.底层的数据结构是数组,内存空间是连续的
3.元素有下标,有序,允许存放重复的元素
4.通常可以根据下标进行操作
5.增删操作比较慢,查询操作比较快[数据量比较大时]

1.4 LinkedList的特点:

1.List接口的实现类
2.底层的数据结构是链表,内存空间是不连续的
3.元素有下标,有序,允许存放重复的元素
4.通常进行首尾节点的操作比较多
5.增删操作比较快,查询操作比较慢[数据量比较大时]
注意: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() 返回并移除尾元素

2. Map接口

Map接口的特点

  1. map集合的结构是:键值对、KEY与VALUE、Map.Entry的映射关系
  2. map中key值不允许重复,如果重复,对应的value会被覆盖
  3. map中的映射关系是无序的
  4. 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> entrySet()
把本map中的每一对KV都看成是一个Entry,把所有的Entry取出放入一个Set集合中并返回这个Set集合

HashMap的存储过程:

  1. HashMap的结构是数组+链表 或者 数组+红黑树 的形式
  2. HashMap底层的Entry[ ]数组,初始容量为16,加载因子是0.75f,扩容按约为2倍扩容
  3. 当存放数据时,会根据hash(key)%n算法来计算数据的存放位置,n就是数组的长度,其实也就是集合的容量
  4. 当计算到的位置之前没有存过数据的时候,会直接存放数据
  5. 当计算的位置,有数据时,会发生hash冲突/hash碰撞
    解决的办法就是采用链表的结构,在数组中指定位置处以后元素之后插入新的元素
    也就是说数组中的元素都是最早加入的节点
  6. 如果链表的长度>8并且数组长度>64时,链表会转为红黑树,当链表的长度<6时,会重新恢复成链表

作业:完成笔记HashMap的相关练习:2.4 练习:字符串中字符统计
需求:随机输入一串字符串,统计这串字符串中每个字母的出现次数

笔记链接 HashMap

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/123922.html

相关文章

  • CGBTN2108-DAY08总结复习

    摘要:复习继承中变量的使用如果父类的成员变量与子类的成员变量同名时,使用变量名指定父类的成员变量继承中构造方法的使用我们每次创建对象的时候,都会先触发构造函数创建子类对象时,会先调用父类的无参构造,因为子类的构造函数中默认存 ...

    pekonchan 评论0 收藏0
  • CGBTN2108_DAY17总结复习

    摘要:设计模式概念是一些前人总结出来的值得学习的编程套路,设计模式一共有种单例设计模式确保代码中本类的实例只有一个实现思路方案一饿汉式把本类的构造方法私有化为了不让外界调用构造函数来创建对象通过本类的构造方法创建对象,并把这 ...

    XFLY 评论0 收藏0
  • C1认证快速复习重点个人总结(一、计算机通识【上】),部分内容同任务文档

    摘要:数据校验计算机网络计组只涉及到奇偶校验,不难信息单位计组计网信息容量最小计量单位位,比特,缩写为小,位一大。七层模型计网七层分别为物理层数据链路层网络层传输层会话层表示层应用层。该层负责上下两层之间的信息转发,建立维持和终止。 ...

    tracy 评论0 收藏0
  • Linux文件权限复习总结

    摘要:打算把最近一年学的做个整理,就从文件权限开始吧基本权限权限高级权限基本权限一个文件对应三种权限对象,分别文件的所有者所属组和其他人每个权限对象对应三种权限,分别是读写和执行权限数字对应关系权限名称十进制二进制这么设计的目的是任意组合不会互相 打算把最近一年学的Linux做个整理,就从文件权限开始吧 ugo基本权限 acl权限 suid,sgid,sticky高级权限 selinux ...

    atinosun 评论0 收藏0
  • 数组的使用总结— (js基础复习第2期)

    摘要:前一个值,当前值,索引,数组对象产生新数组的迭代器方法类似,对数组的每个元素使用某个函数,并返回新数组和相似,传入一个返回值为布尔类型的函数。 1. 前言 数组真的是每天用了,但是有很多方法都是记不住,总是要百度查,很烦,所以才写了个数组使用总结,有什么不对的希望大家指出来。 2. 思路 先看看这些问题都记得很清楚么? 创建数组,怎么创建数组的 数组的构造方法Array有哪些方法?E...

    zhigoo 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<