Java面试题2-集合+数据结构

一、集合

集合的体系

1、集合的特点

集合的特点主要有如下两点:

对象封装数据,对象多了也需要存储。集合用于存储对象。

对象的个数确定可以使用数组,对象的个数不确定的可以用集合。因为集合是可变长度的。

2、集合和数组的区别

1、数组是固定长度的;集合可变长度的。

2、数组可以存储基本数据类型,也可以存储引用数据类型;集合只能存 储引用数据类型。

3、数组存储的元素必须是同一个数据类型;集合存储的对象可以是不同 数据类型。

数据结构:就是容器中存储数据的方式。

3、使用集合框架的好处

  1. 容量自增长;

  2. 提供了高性能的数据结构和算法,使编码更轻松,提高了程序速度和质量;

  3. 允许不同 API 之间的互操作,API之间可以来回传递集合;

  4. 可以方便地扩展或改写集合,提高代码复用性和可操作性

  5. 通过使用JDK自带的集合类,可以降低代码维护和学习新API成本。

4、集合构成

Collection集合主要有List和Set两大接口

1、List:一个有序(元素存入集合的顺序和取出的顺序一致)容器,元素可以重 复,可以插入多个 null元素,元素都有索引。常用的实现类有 ArrayList、LinkedList 和 Vector。

1.1

2、Set:一个无序(存入和取出顺序有可能不一致)容器,不可以存储重复元素, 只允许存入一个 null元素,必须保证元素唯一性。Set 接口常用实现类是 HashSet、 LinkedHashSet 以及 TreeSet。

Map集合一个键值对集合,存储键、值和之间的映射。 Key无序,唯一;value 不要求有序,允许重复。 Map没有继承于Collection接口,从Map集合中检索元 素时,只要给出键对象,就会返回对应的值对象。

Map 的常用实现类:HashMap、TreeMap、HashTable、LinkedHashMap、 ConcurrentHashMap

5、集合框架底层数据结构

Collection

List

1、ArrayList

2、LinkedList

3、Vector

Set

1、HashSet(无序,唯一):基于 HashMap 实现的,底层采用 HashMap 来保存元素

2、LinkedHashSet: LinkedHashSet 继承与 HashSet,并且其内部是通过 LinkedHashMap 来实现 的。有点类似于我们之前说的LinkedHashMap 其内部是基 于 Hashmap 实现一样,不过还是有一 点点区别的。

3、TreeSet(有序,唯一): 红黑树(自平衡的排序二叉树。) Map

4、

相关推荐
雨中飘荡的记忆11 小时前
保证金系统入门到实战
java·后端
Nyarlathotep011311 小时前
Java内存模型
java
NineData13 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
暮色妖娆丶16 小时前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP16 小时前
MyBatis-参数处理与查询结果映射
java
狂奔小菜鸡17 小时前
Day40 | Java中的ReadWriteLock读写锁
java·后端·java ee
SimonKing18 小时前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」
java·后端·程序员
狂奔小菜鸡18 小时前
Day39 | Java中更灵活的锁ReentrantLock
java·后端·java ee
NE_STOP1 天前
MyBatis-配置文件解读及MyBatis为何不用编写Mapper接口的实现类
java