黑马Java基础笔记-15

news2025/5/25 21:10:58

Set

无索引,无序,不可重复

HashSet

object类中默认hashCode的方法是根据地址值

如果集合中存储的是自定义对象,必须要重写hashCodeequals方法

底层原理

jdk8以前:数组 + 链表

jdk8及以后:数组 + 链表 + 红黑树在这里插入图片描述

JDK8以后,当链表长度超过8,而且数组长度大于等于64时自动转换为红黑树


LinkedHashSet

无索引,有序,不可重复

底层原理

在这里插入图片描述


TreeSet

不重复,无索引,可排序(默认从小到大)

底层是红黑树

自定义排序方法:重写compareTo方法传入比较器对象

重写compareTo方法:

在这里插入图片描述

传入比较器对象

在这里插入图片描述

在这里插入图片描述


双列集合

Java Map类继承关系树状图

Map
HashMap
Hashtable
TreeMap
LinkedHashMap
Properties

Map

put的方法的返回值:没有覆盖为null,覆盖元素返回被覆盖的value

遍历

1.键找值

在这里插入图片描述

2.键值对

在这里插入图片描述

3.lambda

底层增强for循环遍历键值对

在这里插入图片描述


HashMap

① HashMap是Map里面的一个实现类。
② 没有额外需要学习的特有方法,直接使用Map里面的方法就可以了。
③ 特点都是由键决定的:无序、不重复、无索引
HashMap跟HashSet底层原理是一模一样的,都是哈希表结构

底层原理

(哈希表)数组(默认长度16)是在添加第一个元素的时候创建,在构造方法执行后是null,还没有创建

扩容双倍

每一个元素都是一个Node(Treenode(红黑树的节点)是Node(链表)的子类)


LinkedHashMap

① 由键决定:有序、不重复、无索引。这里的有序指的是保证存储和取出的元素顺序一致
② 原理:底层数据结构是依然哈希表,只是每个键值对元素又额外的多了一个双链表的机制记录存储的顺序(和LinkedHashSet一致)


TreeMap

① TreeMap跟TreeSet底层原理一样,都是红黑树结构的。
② 由键决定特性:不重复、无索引、可排序

可排序:对键进行排序。
注意:默认按照键的从小到大进行排序,也可以自己规定键的排序规则


面试问题

6.1 TreeMap添加元素的时候,键是否需要重写hashCode和equals方法?
此时是不需要重写的。

6.2 HashMap是哈希表结构的,JDK8开始由数组,链表,红黑树组成的。
既然有红黑树,HashMap的键是否需要实现Comparable接口或者传递比较器对象呢?
不需要的。
因为在HashMap的底层,默认是利用哈希值的大小关系来创建红黑树的

6.3 TreeMap和HashMap谁的效率更高?
如果是最坏情况,添加了8个元素,这8个元素形成了链表,此时TreeMap的效率要更高
但是这种情况出现的几率非常的少。
一般而言,还是HashMap的效率要更高。

6.4 你觉得在Map集合中,java会提供一个如果键重复了,不会覆盖的put方法呢?
putIfAbsent

此时putIfAbsent本身不重要。
传递递一个思想:
代码中的逻辑都有两面性,如果我们只知道了其中的A面,而且代码中还发现了有变量可以控制两面的属性
那么该逻辑一定会有B面。
习惯:
boolean类型的变量控制,一股只有AB两面,因为boolean只有两个值
int类型的变量控制,一股至少有三面,因为int可以取多个值。

6.5三种双列集合,以后如何选择?
HashMap LinkedHashMap TreeMap

  • 默认:HashMap(效率最高)
  • 如果要保证存取有序:LinkedHashMap
  • 如果要进行排序:TreeMap

可变参数

jdk5开始,底层是数组实现

格式:属性类型…名字

int...args

在方法的形参中最多只能写一个可变参数,并且需要写在最后


不可变集合

  • List.of

  • Set.of

    元素不可重复

  • Map.of/Map.ofEntries/Map.copyof

    of最多存10个键值对,元素不可重复

Stream流

获取方式方法名说明
单列集合default Stream<E> stream()Collection中的默认方法
双列集合无法直接使用stream流,需要转化为单列集合
数组public static <T> Stream<T> stream(T[] array)Arrays工具类中的静态方法
一堆零散数据public static<T> Stream<T> of(T... values)Stream接口中的静态方法(不推荐数组使用,基本数据类型的数组无法使用)

Stream的常用中间方法

名称说明
Stream<T> filter(Predicate<? super T> predicate)过滤
Stream<T> limit(long maxSize)获取前几个元素
Stream<T> skip(long n)跳过前几个元素
Stream<T> distinct()元素去重(依赖 hashCodeequals 方法,底层使用hashSet)
static <T> Stream<T> concat(Stream a, Stream b)合并 ab 两个流为一个流
Stream<R> map(Function<T, R> mapper)转换流中的数据类型
Stream.concat(list1.stream(),list2.stream()).forEach(s->System.out.println(s):

注意1:中间方法返回新的 Stream 流,原流仅能使用一次,建议采用链式编程

注意2:修改 Stream 流数据不会影响原始集合/数组

Stream中常用的终结方法

名称说明
void forEach(Consumer action)遍历
long count()统计
toArray()收集流中的数据,放到数组中
collect(Collector collector)收集流中的数据,放到集合中

Collectors.toMap比较特殊,需要传入两个函数

Map<String, Integer> map2 = list.stream()
    // 收集为Map:key=第一个字段,value=第三个字段转整数
    .collect(Collectors.toMap(
        s -> s.split("-")[0],                 // 键提取器
        s -> Integer.parseInt(s.split("-")[2])// 值转换器
    )); 

方法引用

在这里插入图片描述

  • 其他类:其他类对象::方法名

  • 本类:this::方法名(静态方法中引用非静态方法需要new一个非静态方法的对象再::调用)

  • 父类:super::方法名

  • 引用构造方法:类名::new

  • 调用无参方法:需要形参为当前方法引用所在类或者其父类

    Function<String, String> f = String::toUpperCase;  // 首个参数 String 作接收者,OK
    Function<Object, String> g = String::toUpperCase;  // Object 也可作接收者,OK(String 是 Object 子类)
    
    List<String> names = List.of("Alice", "Bob");
    // 方法引用写法
    names.stream()
    .map(String::toUpperCase)//必须是String类中的方法
    
    // 等价的 lambda 写法
    names.stream()
    .map(s -> s.toUpperCase())
    

异常

在这里插入图片描述

在这里插入图片描述

Throwable 的成员方法

方法名称说明
public String getMessage()返回此 throwable 的详细消息字符串
public String toString()返回此可抛出的简短描述
public void printStackTrace()把异常的错误信息输出(system.err)在控制台**(细节:仅仅是打印信息,不会停止程序运行)**

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2385614.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软件设计师“排序算法”真题考点分析——求三连

一、考点分值占比与趋势分析 综合知识题分值统计表 年份考题数量总分值分值占比考察重点2018222.67%时间复杂度/稳定性判断2019334.00%算法特性对比分析2020222.67%空间复杂度要求2021111.33%算法稳定性判断2022334.00%综合特性应用2023222.67%时间复杂度计算2024222.67%分治…

Visual Studio 2019/2022:当前不会命中断点,还没有为该文档加载任何符号。

1、打开调试的模块窗口&#xff0c;该窗口一定要在调试状态下才会显示。 vs2019打开调试的模块窗口 2、Visual Studio 2019提示未使用调试信息生成二进制文件 未使用调试信息生成二进制文件 3、然后到debug目录下看下确实未生成CoreCms.Net.Web.WebApi.pdb文件。 那下面的…

vue--ofd/pdf预览实现

背景 实现预览ofd/pdf超链接功能 业务实现 pdf的预览 实现方式&#xff1a; 直接使用 <iframe :src"${url}#navpanes0&toolbar0" /> 实现pdf的预览。 navpanes0 隐藏侧边栏toolbar0 隐藏顶部工具栏 使用pdf.js&#xff0c;代码先行&#xff1a; <tem…

Python 爬虫之requests 模块的应用

requests 是用 python 语言编写的一个开源的HTTP库&#xff0c;可以通过 requests 库编写 python 代码发送网络请求&#xff0c;其简单易用&#xff0c;是编写爬虫程序时必知必会的一个模块。 requests 模块的作用 发送网络请求&#xff0c;获取响应数据。 中文文档&#xf…

【MySQL】CRUD

CRUD 简介 CRUD是对数据库中的记录进行基本的增删改查操作 Create&#xff08;创建&#xff09;Retrieve&#xff08;读取&#xff09;Update&#xff08;更新&#xff09;Delete&#xff08;删除&#xff09; 一、新增&#xff08;Create&#xff09; 语法&#xff1a; I…

Spring Boot微服务架构(三):Spring Initializr创建CRM项目

使用Spring Initializr创建CRM项目 一、创建项目前的准备 访问Spring Initializr网站&#xff1a; 打开浏览器访问 https://start.spring.io/或者直接使用IDE&#xff08;如IntelliJ IDEA或Eclipse&#xff09;内置的Spring Initializr功能 项目基本信息配置&#xff1a; Proj…

【笔记】PyCharm 中创建Poetry解释器

#工作记录 在使用 PyCharm 进行 Python 项目开发时&#xff0c;为项目配置合适的 Python 解释器至关重要。Poetry 作为一款强大的依赖管理和打包工具&#xff0c;能帮助我们更便捷地管理项目的依赖项与虚拟环境。下面将详细记录在 PyCharm 中创建 Poetry 解释器的步骤。 前提条…

python中的numpy(数组)

&#xff08;0&#xff09;numpy介绍 NumPy是Python中用于科学计算的基础库&#xff0c;提供高效的多维数组对象ndarray&#xff0c;支持向量化运算&#xff0c;能大幅提高数值计算效率。它集成了大量数学函数&#xff08;如线性代数、傅里叶变换等&#xff09;&#xff0c;可…

rce命令执行原理及靶场实战(详细)

2. 原理 在根源上应用系统从设计上要给用户提供一个指定的远程命令操作的接口。漏洞主要出现在常见的路由器、防火墙、入侵检测等设备的web管理界面上。在管理界面提供了一个ping服务。提交后&#xff0c;系统对该IP进行ping&#xff0c;并且返回结果。如果后台服务器并没有对…

Fuzz 模糊测试篇JS 算法口令隐藏参数盲 Payload未知文件目录

1 、 Fuzz 是一种基于黑盒的自动化软件模糊测试技术 , 简单的说一种懒惰且暴力的技术融合了常见 的以及精心构建的数据文本进行网站、软件安全性测试。 2 、 Fuzz 的核心思想 : 口令 Fuzz( 弱口令 ) 目录 Fuzz( 漏洞点 ) 参数 Fuzz( 利用参数 ) PayloadFuzz(Bypass)…

展示了一个三轴(X, Y, Z)坐标系!

等轴测投影”&#xff08;isometric projection&#xff09;风格的手绘风格三维图&#xff0c;即三条坐标轴&#xff08;x₁, x₂, x₃&#xff09;看起来彼此垂直、等角分布&#xff08;通常是 120 夹角&#xff09;&#xff0c;它是常见于教材和数学书籍的 “假三维”表示法。…

【b站计算机拓荒者】【2025】微信小程序开发教程 - chapter1 初识小程序 - 3项目目录结构4快速上手

3 项目目录结构 3.1 项目目录结构 3.1.1 目录介绍 # 1 项目主配置文件&#xff0c;在项目根路径下&#xff0c;控制整个项目的-app.js # 小程序入口文件&#xff0c;小程序启动&#xff0c;会执行此js-app.json # 小程序全局配置文件&#xff0c;配置小程序导航栏颜色等信息…

LLM Tuning

Lora-Tuning 什么是Lora微调&#xff1f; LoRA&#xff08;Low-Rank Adaptation&#xff09; 是一种参数高效微调方法&#xff08;PEFT, Parameter-Efficient Fine-Tuning&#xff09;&#xff0c;它通过引入低秩矩阵到预训练模型的权重变换中&#xff0c;实现无需大规模修改…

云计算与大数据进阶 | 28、存储系统如何突破容量天花板?可扩展架构的核心技术与实践—— 分布式、弹性扩展、高可用的底层逻辑(下)

在上篇中&#xff0c;我们围绕存储系统可扩展架构详细探讨了基础技术原理与典型实践。然而&#xff0c;在实际应用场景中&#xff0c;存储系统面临的挑战远不止于此。随着数据规模呈指数级增长&#xff0c;业务需求日益复杂多变&#xff0c;存储系统还需不断优化升级&#xff0…

水利数据采集MCU水资源的智能守护者

水利数据采集仪MCU&#xff0c;堪称水资源的智能守护者&#xff0c;其重要性不言而喻。在水利工程建设和水资源管理领域&#xff0c;MCU数据采集仪扮演着不可或缺的角色。它通过高精度的传感器和先进的微控制器技术&#xff0c;实时监测和采集水流量、水位、水质等关键数据&…

origin绘图之【如何将横坐标/x设置为文字、字母形式】

在使用 Origin 进行科研绘图或数据可视化的过程中&#xff0c;我们常常会遇到这样一种需求&#xff1a;希望将横坐标&#xff08;X轴&#xff09;由默认的数字形式&#xff0c;改为字母&#xff08;如 A、B、C……&#xff09;或中文文字&#xff08;如 一、二、三……&#xf…

工业智能网关建立烤漆设备故障预警及远程诊断系统

一、项目背景 烤漆房是汽车、机械、家具等工业领域广泛应用的设备&#xff0c;主要用于产品的表面涂装。传统的烤漆房控制柜采用本地控制方式&#xff0c;操作人员需在现场进行参数设置和设备控制&#xff0c;且存在设备智能化程度低、数据孤岛、设备维护成本高以及依靠传统人…

Kafka Streams 和 Apache Flink 的无状态流处理与有状态流处理

Kafka Streams 和 Apache Flink 与数据库和数据湖相比的无状态和有状态流处理的概念和优势。 在数据驱动的应用中&#xff0c;流处理的兴起改变了我们处理和操作数据的方式。虽然传统数据库、数据湖和数据仓库对于许多基于批处理的用例来说非常有效&#xff0c;但在要求低延迟…

LM-BFF——语言模型微调新范式

gpt3&#xff08;GPT3——少样本示例推动下的通用语言模型雏形)结合提示词和少样本示例后&#xff0c;展示出了强大性能。但大语言模型的训练门槛太高&#xff0c;普通研究人员无力&#xff0c;LM-BFF(Making Pre-trained Language Models Better Few-shot Learners)的作者受gp…

NVMe高速传输之摆脱XDMA设计2

NVMe IP放弃XDMA原因 选用XDMA做NVMe IP的关键传输模块&#xff0c;可以加速IP的设计&#xff0c;但是XDMA对于开发者来说&#xff0c;还是不方便&#xff0c;原因是它就象一个黑匣子&#xff0c;调试也非一番周折&#xff0c;尤其是后面PCIe4.0升级。 因此决定直接采用PCIe设…