JAVA—集合框架以及底层数据结构总览(及相关面试题)

本文介绍了Java集合框架的概念,包括与数组的区别、常用集合如List、Set、Map的接口及其实现类,并讨论了集合框架的优势。同时,文章提供了相关面试题,涉及HashSet与HashMap、ArrayList与LinkedList的区别,以及HashMap的实现和线程安全性问题。
摘要由CSDN通过智能技术生成

一、集合框架大纲介绍

1.介绍

因为描述场景不一样,数据组织形式的不同因而有不同的数据结构。
Java 集合框架 Java Collection Framework ,又被称为容器 container ,是定义在 java.util 包下的一组接口 interfaces 和其实现类 classes 。
其主要表现为将多个元素 element 置于一个单元中,用于对这些元素进行快速、便捷的存储 store 、检索retrieve 、管理 manipulate ,即平时我们俗称的增删查改 CRUD 。

类和接口总览
在这里插入图片描述
在这里插入图片描述

2.集合数组的区别

集合:长度可变;内容只能是引用类型;集合可以存储不同类型(但一般都是同一类型)
数组:长度固定:内容可以是基本类型也可以是引用类型;元素只能是一种类型

3.常用集合概述

Collection 接口的接口 对象的集合(单列集合)
├——-List 接口:元素按进入先后有序保存,可重复
│—————-├ LinkedList 接口实现类, 链表, 插入删除, 没有同步, 线程不安全
│—————-├ ArrayList 接口实现类, 数组, 随机访问, 没有同步, 线程不安全
│—————-└ Vector 接口实现类 数组, 同步, 线程安全
│ ———————-└ Stack 是Vector类的实现类
|—–Queue接口:先进先出有序保存,数组和链表的结构实现。
|——————|- LinkedList 接口实现类, 链表, 插入删除, 没有同步, 线程不安全
|——————|-PriorityQueue:底层二叉树,但是具备队列的特性
└——-Set 接口: 仅接收一次,不可重复,并做内部排序
├—————-└HashSet 使用hash表(数组)存储元素
│————————└ LinkedHashSet 链表维护元素的插入次序
└ —————-TreeSet 底层实现为二叉树,元素排好序

Map 接口 键值对的集合 (双列集合)
├———Hashtable 接口实现类, 同步, 线程安全
├———HashMap 接口实现类 ,没有同步, 线程不安全-
│—————–├ LinkedHashMap 双向链表和哈希表实现
│—————–└ WeakHashMap
├ ——

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值