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、

相关推荐
子枫秋月2 小时前
模拟C++string实现
数据结构·c++·算法
码农水水2 小时前
大疆Java面试被问:Spring事务的传播行为详解
java·数据库·spring
羚羊角uou2 小时前
【数据结构】常见排序
数据结构·算法·排序算法
winfield8212 小时前
GC 日志全解析:格式规范 + 问题分析 + 性能优化
java·jvm
甜可儿2 小时前
mac环境安装不同版本maven
java·macos·maven
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 基于SpringBoot的智慧商城系统设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
十五年专注C++开发2 小时前
QProcess在Windows下不能正常启动exe的原因分析
开发语言·c++·windows·qprocess·createprocess
无限进步_2 小时前
C++多态全面解析:从概念到实现
开发语言·jvm·c++·ide·git·github·visual studio
.似水2 小时前
Python面向对象
开发语言·python