【面试小知识】Collection(接口)集合

简介: 【面试小知识】Collection(接口)集合

1. 简介

近期,在牛客网看到关于collection接口集合的问题,一时间自己没想起来,于是自己整理了一下。

2. Collection(接口)集合架构

3.集合分析

我们可以看到,关于Collection主要分为常见的Set、list、queue

3.1 Set(接口、无序、无索引、不重复性)

对于set集合,一般我们在用的时候,主要利用其不重复性,比如我们在筛选数据时,放进去,提出来,Set集合自动帮我们去除掉重复的数据

  • HashSet:底层数据结构是哈希表(无序,唯一)。保证元素唯一性依赖于两个方法:hashCode()和equals()
  • LinkedHashSet:底层数据结构是链表和哈希表。(先入先出,有序,唯一)。通过链表保证有序性, 通过哈希表保证唯一性。
  • TreeSet:底层数据结构是红黑树。(唯一,有序)

这里主要谈一下关于Set数组去重的问题,在Set源码中,boolean add(E e);我们看到关于其添加的操作是一个boolean的判断值,也就是我们在添加数据时,需要判断当前Set中有没有该数据。

在HashSet中,利用HashCode()和equals()进行比较:

补充:关于HashCode:通过对象的内部地址(也就是物理地址)转换成一个整数,然后该整数通过hash函数的算法就得到了hashcode

详情参考:HashCode

这也是为什么我们在重写时,HashCode和equals要一起重写的原因

看上图,我们重写了equals()函数,只要传入的对象的w/q一样就返回true,但是,我们看上述流程图会发现,他们会先进行HashCode的比较,所以,在HashCode这一关过不去,就更不用谈equals()了。

3.2 list(有序,可重复。)

  • ArrayList:底层实现的数据结构是数组,查询快,增删慢。线程不安全,效率高
  • LinkedList:底层实现的数据结构是链表,查询慢,增删块。线程不安全,效率高
  • Vector:底层实现的数据结构是数组,查绚块,增删慢。线程安全,效率低。

关于ArrayList和LinkedList的区别以及ArrayList的扩容机制:ArrayList和LinkedList

3.3 queue(队列)

  • queue:先进先出
  • Dueue:双向队列,可以两端对数据进行操作
  • priorityqueue(优先队列):按照给定的优先级,进行出队列,用于迪杰斯特拉算法,用于计算最短路径。


相关文章
|
8天前
|
决策智能
集合-Nim游戏(面试hard博弈论)
集合-Nim游戏(面试hard博弈论)
|
8天前
|
设计模式 算法 Java
后端面试题:接口和抽象类的区别?抽象类可以多继承吗?
字节后端面试题:接口和抽象类的区别?抽象类可以多继承吗?
29 0
|
3天前
|
数据采集 关系型数据库 MySQL
2024年最全python进阶系列- 04 集合,2024年最新哈希表 面试
2024年最全python进阶系列- 04 集合,2024年最新哈希表 面试
|
3天前
|
开发工具 Python 容器
2024年最全python进阶系列- 04 集合(1),面试高频问题回答
2024年最全python进阶系列- 04 集合(1),面试高频问题回答
2024年最全python进阶系列- 04 集合(1),面试高频问题回答
|
5天前
|
存储 索引 Python
【python学习】列表、元组、字典、集合,秋招是不是得到处面试
【python学习】列表、元组、字典、集合,秋招是不是得到处面试
|
6天前
|
定位技术 API
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
Angular 调用导入百度地图API接口,2024春招BAT面试真题详解
|
8天前
|
存储 安全 Java
[Java基础面试题] Map 接口相关
[Java基础面试题] Map 接口相关
|
8天前
|
Java
面试官:集合使用时应该注意哪些问题?我:应该注意该注意的问题!
面试官:集合使用时应该注意哪些问题?我:应该注意该注意的问题!
17 1
|
8天前
|
存储 安全 Java
Java集合篇之set,面试官:请说一说HashSet、LinkedHashSet、TreeSet的区别?
Java集合篇之set,面试官:请说一说HashSet、LinkedHashSet、TreeSet的区别?
15 0
|
8天前
|
存储 安全 Java
多线程编程常见面试题讲解(锁策略,CAS策略,synchronized原理,JUC组件,集合类)(下)
多线程编程常见面试题讲解(锁策略,CAS策略,synchronized原理,JUC组件,集合类)(下)
45 0