集合框架及背后的数据结构

news/2025/3/13 3:58:39/

集合框架及背后的数据结构

  • 1. 介绍
  • 2. 学习的意义
    • 2.1 Java 集合框架的优点及作用
    • 2.2 笔试及面试题
  • 3. 接口 `interfaces`
    • 3.1 基本关系说明
    • 3.2 Collection 接口说明
    • 3.3 Collection 常用方法说明
    • 3.4 Collection 示例
    • 3.5 Map 接口说明Map
    • 3.6 Map 常用方法说明
    • 3.7 Map 示例
  • 4. 实现 `classes`
  • 5.数据结构总知识点

大家好,我是晓星航。今天为大家带来的是 集合框架及背后的数据结构 的讲解!😀

1. 介绍

官方教程

Java 集合框架 Java Collection Framework ,又被称为容器 container ,是定义在 java.util 包下的一组接口 interfaces 和其实现类 classes

其主要表现为将多个元素 element 置于一个单元中,用于对这些元素进行快速、便捷的存储 store 、检索retrieve 、管理 manipulate ,即平时我们俗称的增删查改 CRUD

例如,一副扑克牌(一组牌的集合)、一个邮箱(一组邮件的集合)、一个通讯录(一组姓名和电话的映射关系)等等。

类和接口总览

下面我们为大家初步指定三个小问题,希望大家在看完本文章后能对这三个问题有一个清晰的认识。

1、了解清楚,接口和接口之间的关系。

2、了解清楚,接口和类之间的关系。

3、了解清楚,每个类背后的数据结构大概是个啥?

2. 学习的意义

2.1 Java 集合框架的优点及作用

  • 使用成熟的集合框架,有助于我们便捷、快速的写出高效、稳定的代码
  • 学习背后的数据结构知识,有助于我们理解各个集合的优缺点及使用场景

2.2 笔试及面试题

腾讯-Java后台开发面经

  1. HashMap 了解不,介绍一下,如果一个对象为 key 时,hashCode 和 equals 方法的用法要注意什么?
  2. HashSet 和 HashMap 的区别是什么?
  3. HashMap 是线程安全的么?那需要线程安全需要用到什么?

阿里巴巴-Java后台开发面经

  1. ArrayList 和 LinkedList 的区别是什么?
  2. 有了解过 HashMap 的具体实现么?
  3. HashMap 和 ConcurrentHashMap 哪个效率更高?

今日头条-Java后台开发面经

  1. 编程题:判断一个链表是否是一个回文链表。
  2. Redis 的 zset 类型对应到 java 语言中大致是什么类型?
  3. hashCode 主要是用来做什么用的?

3. 接口 interfaces

3.1 基本关系说明

    1. Collection :用来存储管理一组对象 objects ,这些对象一般被成为元素 elements
      1. Set : 元素不能重复,背后隐含着查找/搜索的语义
        1. SortedSet : 一组有序的不能重复的元素
      1. List : 线性结构
      1. Queue : 队列
      1. Deque : 双端队列
    1. Map : 键值对 Key-Value-Pair ,背后隐含着查找/搜索的语义
      1. SortedMap : 一组有序的键值对

3.2 Collection 接口说明

Collection 官方文档

3.3 Collection 常用方法说明

add方法演示:

Collection<String> collection = new ArrayList<>();
collection.add("xxh");

在没规定前,collection的add方法中什么都可以添加。

而在规定了后,collection的add方法就只能添加字符串了。

claer方法演示:

Collection<String> collection = new ArrayList<>();
collection.add("xxh");
collection.add("ljq");
System.out.println(collection);
collection.clear();
System.out.println("==============");
System.out.println(collection);

这里不难看出在使用clear方法清除后,我们的元素就全部清空了

Object[] toArray()方法演示:

Collection<String> collection = new ArrayList<>();
collection.add("xxh");
collection.add("ljq");
//System.out.println(collection);
Object[] objects = collection.toArray();
System.out.println(Arrays.toString(ob

3.4 Collection 示例

import java.util.Collection;
import java.util.ArrayList;
import java.util.Arrays;
public class TestDemo {public static void main(String[] args) {Collection<String> list = new ArrayList<>();System.out.println(list.size());System.out.println(list.isEmpty());list.add("我");list.add("爱");list.add("Java");System.out.println(list.size());System.out.println(list.isEmpty());Object[] array = list.toArray();System.out.println(Arrays.toString(array));for (String s : list) {System.out.println(s);}list.remove("爱");for (String s : list) {System.out.println(s);}list.clear();System.out.println(list.size());System.out.println(list.isEmpty());}
}

3.5 Map 接口说明Map

官方文档

3.6 Map 常用方法说明

3.7 Map 示例

import java.util.Map;
import java.util.HashMap;
public class TestDemo {public static void main(String[] args) {Map<String, String> map = new HashMap<>();System.out.println(map.size());System.out.println(map.isEmpty());System.out.println(map.get("作者"));System.out.println(map.getOrDefault("作者", "佚名"));System.out.println(map.containsKey("作者"));System.out.println(map.containsValue("佚名"));map.put("作者", "鲁迅");map.put("标题", "狂人日记");map.put("发表时间", "1918年");System.out.println(map.size());System.out.println(map.isEmpty());System.out.println(map.get("作者"));System.out.println(map.getOrDefault("作者", "佚名"));System.out.println(map.containsKey("作者"));System.out.println(map.containsValue("佚名"));for (Map.Entry<String, String> entry : map.entrySet()) {System.out.println(entry.getKey());System.out.println(entry.getValue());}}
}

4. 实现 classes

5.数据结构总知识点

  1. 集合框架的使用

    1. Collection
    2. List
    3. ArrayList
    4. LinkedList
    5. Stack
    6. Queue
    7. PriorityQueue
    8. Deque
    9. Set
    10. HashSet
    11. TreeSet
    12. Map
    13. HashMap
    14. TreeMap
    15. Collections
  2. 数据结构的理论及实现

    1. 顺序表
    2. 链表
    3. 队列
    4. 二叉树
  3. 排序算法

    1. 插入排序
    2. 希尔排序
    3. 选择排序
    4. 堆排序
    5. 冒泡排序
    6. 快速排序
    7. 归并排序
  4. Java 语法

    1. 泛型 Generic
    2. 自动装箱 autobox 和自动拆箱 autounbox
    3. Objectequals 方法
    4. ComparableComparator 接口

感谢各位读者的阅读,本文章有任何错误都可以在评论区发表你们的意见,我会对文章进行改正的。如果本文章对你有帮助请动一动你们敏捷的小手点一点赞,你的每一次鼓励都是作者创作的动力哦!😘


http://www.ppmy.cn/news/13014.html

相关文章

【自学Docker 】Docker top命令

Docker top命令 大纲 docker top教程 使用 docker top 命令可以用来查看 Docker 中运行的进程信息。docker top 命令后面的 CONTAINER 可以是容器 ID&#xff0c;或者是容器名。 docker top语法 haicoder(www.haicoder.net)# docker top [OPTIONS] CONTAINER [ps OPTIONS]案…

10款最佳在线地图软件介绍

有人说&#xff1a;一个人从1岁活到80岁很平凡&#xff0c;但如果从80岁倒着活&#xff0c;那么一半以上的人都可能不凡。 生活没有捷径&#xff0c;我们踩过的坑都成为了生活的经验&#xff0c;这些经验越早知道&#xff0c;你要走的弯路就会越少。 在线地图有无数的用途&…

<Python>使用python来控制windows系统音量

使用python可以对windows系统的音量进行读取或者设置。 平台&#xff1a;visual studio code 语言&#xff1a;python 需要的python模块&#xff1a; 1、pyqt5 2、ctypes&#xff1a; ctypes 是 Python 的外部函数库。它提供了与 C 兼容的数据类型&#xff0c;并允许调用 DLL …

【SpringCloud13】SpringCloud Config分布式配置中心

1.概述 1.1 分布式系统面临的配置问题 微服务意味着要将单体应用中的业务拆分成一个个子服务&#xff0c;每个服务的粒度相对较小&#xff0c;因此系统中会出现大量的服务。由于每个服务都需要必要的配置信息才能运行&#xff0c;所以一套集中式的、动态的配置管理设施是必不…

联合变换相关器摄远物镜光学设计

联合变换相关器摄远物镜光学设计 联合变换相关器工作原理 随着科学技术的飞速发展&#xff0c;光学相关探测器件由最初的匹配滤波器发展到今天的联合变换相关器&#xff0c;联合变换相关器与范得耳-卢格特相关器相比&#xff0c;具有灵活性好、识别精度高等特点&#xff0c;所…

4.4 可迭代对象(Iterable)与迭代器(Iterator)

4.4 可迭代对象(Iterable)与迭代器&#xff08;Iterator&#xff09; 4.4.1 可迭代&#xff08;Iterable&#xff09;对象 如果一个对象实现了__iter__方法&#xff0c;那么这个对象就是可迭代&#xff08;Iterable&#xff09;对象>>> #如何知道一个对象实现了那些…

如何格式化U盘?以及优盘格式化的恢复方法

我们经常使用U盘来进行存储和传输数据&#xff0c;使用时间久了&#xff0c;可能需要我们进行优盘格式化。需要注意&#xff01;优盘格式化之前&#xff0c;记得对里面的数据进行备份&#xff0c;防止数据清空造成不必要的损失。 如何进行U盘格式化&#xff1f;格式化优盘后&a…

软考初级哪个好考

其实软考初级的实用性差不多。只是看自身怎么看&#xff0c;考哪一科对你来说&#xff0c;产生的意义更大&#xff0c;对自己以后的发展前景帮助大&#xff0c;那你就选择哪一科就行。 软考初级科目有&#xff1a;程序员、网络管理员、信息处理技术员、信息系统运行管理员、网…