当前位置: 首页 > news >正文

HashMap ,HashTable , ConcurrentHashMap 面试

双列集合

HashMap 线程不安全的

HashMap 允许键和值为 null。不过要留意,HashMap 并非线程安全的,在多线程环境下使用可能会出现问题。

数组链表+红黑树          jdk1.8

双列集合 存储keyvalue 底层数组的形式存在,初始值 为16 也可以在new HashMap的时候指定HashMap的大小new出来的大小是2的幂次方 负载因子为0.75

static final int DEFAULT_INITIAL_CAPACITY = 1 << 4

数组中每一个元素称为hash桶 每次put一个元素时根据它的key算出它的hashcode 然后对数组的长度取余算出他在哪个位置,如果该位置hash桶没有东西则直接放,如果该位置有,,则通过eques方法比较如果key相同,则更新value如果不同则再放,如果放的时候该位置的痛的数量没有超过8,则通过尾差发放上去,如果超过8,则判断数组的大小有没有超过64,如果超过64,则转为红黑树,没有超过64则将数组的长度扩容至两倍,扩容时采取数据迁移,将原来的链表挪到新数组上去, 不是复制,也不是直接全部挪,jdk1.7将该rehash 重新取模

jdk1.8通过位运算符 hash& 你的老数组长度

低位元素依然放到原来的位置,然后高位放在原来的+扩容的长度

Hashtable是线程安全的,方法上都加了锁 假如有两个线程同时读,也只能一个一个的读,并发效率低

Hashtable同样不允许键或值为null。它也是线程安全的,在设计时就不支持null,若尝试插入null键或值,会抛出NullPointerException

ConcurrentHashMap 线程安全(分段锁)将锁的粒度进一步细化,提高并发效率

ConcurrentHashMap不允许键或值为null。因为它是线程安全的,设计时为了避免在多线程环境下出现NullPointerException等问题,所以不支持null 避免歧义

 如果该节点没有值,并且没有锁,则采用cas比较并交换思想,实现多线程的put操作

相关文章:

HashMap ,HashTable , ConcurrentHashMap 面试

双列集合 HashMap 线程不安全的 HashMap 允许键和值为 null。不过要留意&#xff0c;HashMap 并非线程安全的&#xff0c;在多线程环境下使用可能会出现问题。 数组链表红黑树 jdk1.8 双列集合 存储keyvalue 底层数组的形式存在,初始值 为16 也可以在new HashMap…...

PyTorch 系列教程:探索自然语言处理应用

本文旨在介绍如何使用PyTorch进行自然语言处理&#xff08;NLP&#xff09;的基础知识&#xff0c;包括必要的库、概念以及实际代码示例。通过阅读本文&#xff0c;您将能够开始您的NLP之旅。 1. 理解PyTorch PyTorch是一个开源的机器学习库&#xff0c;基于Torch库&#xff0…...

【操作系统安全】任务2:用户与用户组

目录 一、用户与用户组介绍 1.1 用户 1.2 用户组 1.3 用户与用户组的关系 二、用户与用户组管理 2.1 用户管理 2.1.1 创建用户 2.1.2 设置用户密码 2.1.3 删除用户 2.2 用户组管理 2.2.1 创建用户组 2.2.2 删除用户组 2.2.3 将用户添加到用户组 三、影子账户创建…...

DeepSeek技术解析:MoE架构实现与代码实战

以下是一篇结合DeepSeek技术解析与代码示例的技术文章&#xff0c;重点展示其核心算法实现与落地应用&#xff1a; DeepSeek技术解析&#xff1a;MoE架构实现与代码实战 作为中国AI领域的创新代表&#xff0c;DeepSeek在混合专家模型&#xff08;Mixture of Experts, MoE&…...

LLM对齐方法作用:主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题

LLM对齐方法作用:主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题 对齐方法(Alignment Methods) 主要解决大型语言模型(LLMs)输出与人类价值观、需求和安全规范不一致的问题。其核心目标是让模型生成的内容更符合人类预期,同时确保伦理合规性…...

【SpringMVC】常用注解:@RequestBody

1.作用 用于获取请求实体内容&#xff0c;直接使用得到的是keyvalue&keyvalue的数据。获取请求实体内容不适用get请求。 2.属性 required 描述是否有请求体&#xff0c;默认值为true。当取值为true时&#xff0c;get 请求方式会报错。如果取值为false&#xff0c;get请…...

brpc中的doublyBufferedData解析

double buffer解析&#xff08;附brpc改进版&#xff09; 双buffer是一个工程中常见的解决读写问题的结构。指的是读只读buff&#xff0c;写操作发生在写buff上。当写buff写完之后switch两个buff&#xff0c;然后写进程擦除原来的读数据&#xff0c;更新为最新的数据。 我们有…...

基于Android的记事本APP设计与实现:从需求分析到功能实现(超级简单记事本,附源码+文档报告)

基于Android的记事本APP设计与实现&#xff1a;从需求分析到功能实现 &#xff08;以前大学课堂作业&#xff0c;抄在这里当个回忆吧&#xff09; 引言 随着社会的不断进步&#xff0c;信息化建设不断发展&#xff0c;电子文字输入在生活、学习、工作中占有越来越重要的作用…...

Linux 部署 Spring Boot 项目, Web项目(2025版)

Linux 部署 Spring Boot 项目&#xff0c;Web项目&#xff08;2025版&#xff09; 一、简洁版1.1 Linux 环境配置1.2 将Spring Boot 项目部署到 Linux 中 二、详细版2.1 Linux 环境配置2.2 Spring Boot 项目搭建2.3 mysql 配置2.4 测试项目2.5 将Spring Boot 项目部署到 Linux …...

泛目录技术:智能缓存提升网站速度与稳定性

泛目录技术&#xff1a;智能缓存提升网站速度与稳定性 在现代网站运营中&#xff0c;速度和稳定性是用户体验和SEO优化的关键因素。2025奥顺互联推出的泛目录技术&#xff0c;通过智能缓存机制&#xff0c;为网站提供了卓越的性能提升和稳定性保障。本文将深入探讨该技术的特点…...

CNN SSP, ASPP, PPM 分割任务经典尺度聚合模块

SSP&#xff1a;Spatial Pyramid Pooling 让任意大小图像最终输出的特征维度始终固定&#xff0c;便于接全链接层。 4x4, 2x2,1x1区域的maxpooling&#xff0c;让任意大小图像最终输出最终特征维度始终为 &#xff08;1641)*256 ASSP:Atrous Spatial Pyramid Pooling 不进行…...

Nping- Nmap中的一个工具-用于生成网络数据包并分析响应

Nping 工具介绍 Nping 是 Nmap 项目中的一个网络工具&#xff0c;用于生成网络数据包并分析响应。它可以用于网络探测、性能测试、防火墙测试、ARP 欺骗检测等多种场景。Nping 支持多种协议&#xff08;如 TCP、UDP、ICMP、ARP&#xff09;&#xff0c;并允许用户自定义数据包…...

海马下载 1.0.2 | 纯净无广告,极简设计,不限速下载工具

海马下载是一款轻量级下载工具&#xff0c;仅保留核心链接下载功能&#xff0c;体积小巧仅21MB。实测无广告弹窗且不限速&#xff0c;适合追求简洁体验的用户。操作界面直观易用&#xff0c;可快速添加任务并查看下载进度。 大小&#xff1a;21M 下载地址&#xff1a; 百度网…...

【蓝桥杯—单片机】第十五届省赛真题代码题解析 | 思路整理

第十五届省赛真题代码题解析 前言赛题代码思路笔记竞赛板配置建立模板明确基本要求显示功能部分频率界面正常显示高位熄灭 参数界面基础写法&#xff1a;两个界面分开来写优化写法&#xff1a;两个界面合一起写 时间界面回显界面校准校准过程校准错误显示 DAC输出部分按键功能部…...

maven之自定义插件

写在前面 在使用maven肯定是离不开插件的&#xff0c;比如执行mvn clean或者时mvn compile其实运行的就是绑定的默认插件。虽然我们一般不需要来自定义插件&#xff0c;但是为了使用的过程中更加的清晰&#xff0c;来尝试自定义插件还是很有必要的&#xff0c;所以本文就一起来…...

Unity单例模式(c#泛型基类)

Unity单例模式 1 单例模式2 继承mono脚本单例模式基类3 SingletonAutoMono脚本 1 单例模式 单例模式基类模块 范型加约束,支持new来构造 //单例模式基类模块 //范型加约束,支持new来构造 public class BaseManager<T> where T :new() {private static T instance;public …...

java 中桥方法(Bridge Method)解决泛型和多态(即:类型兼容)而存在的

在 Java 中&#xff0c;**桥方法&#xff08;Bridge Method&#xff09;**是编译器自动生成的一种方法&#xff0c;主要用于解决泛型类型擦除和继承中的类型兼容性问题。以下是关于桥方法的几点关键信息&#xff1a; 1. 桥方法的作用 类型擦除兼容性&#xff1a;Java 的泛型在…...

Centos7阿里云yum源

#Step1:下载repository 没有wget命令 就用curl wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo #Step2:安装epel基础组件源 没有wget命…...

leetcode 102. 二叉树的层序遍历

方法一&#xff1a; 用两个数组进行迭代遍历 class Solution {public List<List<Integer>> levelOrder(TreeNode root) {if(root null) {return new ArrayList<List<Integer>>();}List<TreeNode> cur new ArrayList<TreeNode>();cur.a…...

Trae插件革命:用VSPlugin Helper实现VSCode市场插件全自动安装

之前有读者留言说trae都没有c的插件用&#xff0c;确实是这样&#xff0c;trae的插件源用的是open vsx&#xff0c;而c/c插件是vscode官方插件市场的&#xff0c;如果想直接在trae中安装c/c插件是不行的&#xff0c;只能先从vscode官方插件市场把vsix后缀文件先下载下来&#x…...

SpringCloud带你走进微服务的世界

认识微服务 随着互联网行业的发展&#xff0c;对服务的要求也越来越高&#xff0c;服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢&#xff1f; 单体架构 单体架构&#xff1a;将业务的所有功能集中在一个项目中开发&#xff0c;打成一个包部…...

多线程(超详细) (ε≡٩(๑>₃<)۶ 一心向学)

多线程目录 一、认识线程 1、概念&#xff1a; 1) 线程是什么 2) 线程为什么存在 3) 进程与线程的区别 二、创建线程 1、方法1&#xff1a;继承Thread类 2、方法2&#xff1a;实现 Runnable 接口 3、方法3&#xff1a;匿名内部类创建 Thread 子类对象 4、方法4&#…...

LabVIEW旋转设备状态在线监测系统

为了提高大型旋转设备如电机和水泵的监控效率和故障诊断能力&#xff0c;用LabVIEW软件开发了一套实时监测与故障诊断系统。该系统集成了趋势分析、振动数据处理等多项功能&#xff0c;可实时分析电机电流、压力、温度及振动数据&#xff0c;以早期识别和预报故障。 ​ 项目背…...

RSS和TSS在网络流量处理中的优化作用

摘要 本文深入探讨了RSS(Receive Side Scaling)和TSS(Transmit Side Scaling)这两种网络流量处理技术的实现方法及其在网络性能优化中的重要作用。通过对硬件和软件实现方式的详细分析,阐述了它们如何在多队列网卡、多核处理器系统以及虚拟化环境中提升网络处理性能和吞吐…...

C++ 中的 RTTI(Run-Time Type Information,运行时类型识别)

我来为你详细讲解 C 中的 RTTI&#xff08;Run-Time Type Information&#xff0c;运行时类型识别&#xff09;&#xff0c;并结合你提供的参考内容进行分析和说明。 什么是 RTTI&#xff1f; RTTI 是 C 提供的一种机制&#xff0c;允许程序在运行时识别对象的类型信息。它主要…...

Netty基础—4.NIO的使用简介二

大纲 1.Buffer缓冲区 2.Channel通道 3.BIO编程 4.伪异步IO编程 5.改造程序以支持长连接 6.NIO三大核心组件 7.NIO服务端的创建流程 8.NIO客户端的创建流程 9.NIO优点总结 10.NIO问题总结 4.伪异步IO编程 (1)BIO的主要问题 (2)BIO编程模型的改进 (3)伪异步IO编程 …...

WPS 接入 DeepSeek-R1 深度实践:打造全能AI办公助手

一、智能化办公革命的技术底座 1.1 全球办公自动化发展现状 根据Gartner 2024年数字化转型报告显示&#xff0c;全球83%的企业已启动文档处理智能化改造&#xff0c;其中中国企业的AI办公渗透率以年均37%的增速领跑全球。WPS Office凭借其月活设备数突破5.6亿的生态优势&…...

MySQL与Redis的缓存一致性问题

MySQL与Redis的缓存一致性问题 前言 在学习中&#xff0c;为了提高数据的读取效率&#xff0c;我们往往会使用Redis来作为MySQL数据的缓存&#xff0c;那么&#xff0c;自然就产生了二者间数据的一致性问题。 想要对MySQL和Redis进行数据处理&#xff0c;自然会产生以下问题…...

【前端文件下载实现:多种表格导出方案的技术解析】

前端文件下载实现&#xff1a;多种表格导出方案的技术解析 背景介绍 在企业级应用中&#xff0c;数据导出是一个常见需求&#xff0c;特别是表格数据的导出。在我们的管理系统中&#xff0c;不仅需要支持用户数据的Excel导出&#xff0c;还需要处理多种格式的表格文件下载&am…...

933. 最近的请求次数

最近的请求次数 题目描述尝试做法推荐做法 题目描述 写一个 RecentCounter 类来计算特定时间范围内最近的请求。 请你实现 RecentCounter 类&#xff1a; RecentCounter() 初始化计数器&#xff0c;请求数为 0 。 int ping(int t) 在时间 t 添加一个新请求&#xff0c;其中 …...

[C++Qt] 槽函数收不到信号问题(信号的注册)

&#x1f4e2;博客主页&#xff1a;https://loewen.blog.csdn.net&#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;本文由 丶布布原创&#xff0c;首发于 CSDN&#xff0c;转载注明出处&#x1f649;&#x1f4e2;现…...

吴恩达机器学习笔记复盘(三)Jupyter NoteBook

Jupyter NoteBook Jupyter是一个开源的交互式计算环境&#xff1a; 特点 交互式编程&#xff1a;支持以单元格为单位编写和运行代码&#xff0c;用户可以实时看到代码的执行结果&#xff0c;便于逐步调试和理解代码逻辑。多语言支持&#xff1a;不仅支持Python&#xff0c;还…...

面向对象Demo02

方法的调用的回顾 package oop; ​ public class Demo02 {//静态public static void main(String[] args) {//student student new student();student.speak();//非静态 //student student new student();} } package oop; ​ public class student {public static void sp…...

Quitzilla 学习版(安卓):戒掉坏习惯的高效助手

Quitzilla 是一款源自国外的日程管理工具&#xff0c;专为帮助用户戒除不良习惯而设计。它通过强大的习惯追踪功能和丰富的激励机制&#xff0c;让用户能够清晰地看到自己的进步&#xff0c;并逐步克服成瘾行为。这款软件的前身是一款戒烟应用&#xff0c;但经过改进后&#xf…...

AWB-illuminant_weight_vector

1.概念 光源权重向量 AWB 处理通过求取R/G-B/G 空间中灰色统计数据位置的平均值来估计光源, 此估计基于灰度世界假设. 因此, 输入统计数据中真实的灰色统计数据很重要. 通用环境下,灰色统计数据的平均值会遭到灰色区中的非灰色统计数据污染. 因此,估计结果的精确性依赖与选择灰…...

微信小程序面试内容整理-数据绑定

在微信小程序中,数据绑定是将 JavaScript 中的数据与 WXML 中的视图进行关联和同步的过程。它使得视图可以根据数据的变化自动更新,极大地简化了前端开发的复杂度。 数据绑定有两种主要类型: 1. 单向数据绑定:数据从 Java器更新到视图。...

蓝桥每日打卡--背包问题

#蓝桥#JAVA#背包问题 题目描述 有一个背包&#xff0c;它的容量为 W 4。有 3 个物品&#xff0c;它们的重量分别为 [2, 1, 3]&#xff0c;价值分别为 [4, 2, 3]。问在不超过背包容量的情况下&#xff0c;能装入背包的物品的最大价值是多少&#xff1f; 解题思路 动态规划的…...

基于图像比对的跨平台UI一致性校验工具开发全流程指南——Android/iOS/Web三端自动化测试实战

一、需求背景与方案概述 1.1 为什么需要跨平台UI校验&#xff1f; 在移动互联网时代&#xff0c;同一产品需覆盖Android、iOS和Web三端。由于不同平台的开发框架&#xff08;如Android的Material Design与iOS的Cupertino风格&#xff09;及渲染引擎差异&#xff0c;UI界面易出…...

3D点云目标检测——KITTI数据集读取与处理

一、 数据基本情况 KITTI数据集是由德国卡尔斯鲁厄理工学院和丰田美国技术研究院联合创建的一个大规模自动驾驶场景下的计算机视觉算法评测数据集。以下是关于它的详细介绍&#xff1a; 数据集背景&#xff1a;为评估自动驾驶中计算机视觉算法的性能而设计。自动驾驶汽车需在…...

【鸿蒙开发】Hi3861学习笔记- 外部中断

00. 目录 文章目录 00. 目录01. 概述02. EXTI相关API03. 硬件设计04. 软件设计05. 实验现象06. 附录 01. 概述 我们在做按键控制实验时&#xff0c;虽然能实现 IO 口输入功能&#xff0c;但代码是一直在检测 IO 输入口的变化&#xff0c;因此效率不高&#xff0c;特别是在一些…...

技术与情感交织的一生 (一)

目录 一条朋友圈 静默 至暗时刻 选择 成人高考 歇一下 一条朋友圈 大年初一是我合作伙伴的生日&#xff0c;我称呼他为老高&#xff0c;他发的朋友圈写到&#xff1a;“50岁了&#xff0c;留下的皆是珍贵回忆。” &#xff0c;看到留言的瞬间&#xff0c;只有一个感觉&a…...

30天学习Java第六天——Object类

Object类 java.lang.Object时所有类的超类。Java中所有类都实现了这个类中的方法。 toString方法 将Java对象转换成字符串的表示形式。 public String toString() {return getClass().getName() "" Integer.toHexString(hashCode()); }默认实现是&#xff1a;完…...

基于WebRTC与P2P技术,嵌入式视频通话EasyRTC实现智能硬件音视频交互,适配Linux、ARM、RTOS、LiteOS

EasyRTC不仅仅是一个连接工具&#xff0c;更是一个经过深度优化的通信桥梁。它在嵌入式设备上进行了特殊优化&#xff0c;通过轻量级SDK设计、内存和存储优化以及硬件加速支持&#xff0c;解决了传统WebRTC在嵌入式设备上的适配难题&#xff0c;显著节省了嵌入式设备的资源。 1…...

向量库集成指南

文章目录 向量库集成指南Chroma集成Pinecone集成MiLvus集成向量库集成指南 向量库是一种索引和存储向量嵌入以实现高效管理和快速检索的数据库。与单独的向量索引不同,像Pinecone这样的向量数据库提供了额外的功能,例如,索引管理、数据管理、元数据存储和过滤,以及水平扩展…...

深度研究deep-research优秀开源项目

原文链接:https://i68.ltd/notes/posts/20250305-deep-research2/ 港大开源AI科研神器AI-Researcher 项目仓库:GitHub - HKUDS/AI-Researcher: "AI-Researcher: Fully-Automated Scientific Discovery with LLM Agents" & "Open-Sourced Alternative to G…...

芯谷D8563TS:低功耗CMOS实时时钟/日历电路的优选方案

在电子设备中&#xff0c;实时时钟&#xff08;RTC&#xff09;电路对于提供准确的时间和日历信息至关重要。芯谷D8563TS作为一款低功耗的CMOS实时时钟/日历电路&#xff0c;以其丰富的功能、高精度和灵活的可编程性&#xff0c;成为众多嵌入式系统和电池供电设备中的理想选择。…...

FPGA中级项目1——IP核(ROM 与 RAM)

FPGA中级项目1——IP核&#xff08;ROM 与 RAM&#xff09; IP核简介 在 FPGA&#xff08;现场可编程门阵列&#xff09;设计中&#xff0c;IP 核&#xff08;Intellectual Property Core&#xff0c;知识产权核&#xff09;是预先设计好的、可重用的电路模块&#xff0c;用于实…...

Redis的持久化-AOF

1.AOF AOF&#xff08;Append Only File&#xff09;持久化&#xff1a;以独立日志的方式记录每次写命令&#xff0c;重启时在重新执行AOF文件中的命令达到恢复数据的目的。AOF的主要作用是解决了数据持久化的实时性&#xff0c;目前已经是Redis持久化的主流方式。理解掌握好A…...

jmeter-sample

jmeter-sample http request:接口测试常用请求参数ParametersBody DataFiles Upload jdbc request配置JDBC Connection Configuration创建JDBC Requst请求 http request:接口测试常用 请求参数 Parameters 常见于get请求&#xff0c;与拼在接口后面是一样的效果&#xff1a;如…...

2025-03-15 学习记录--C/C++-PTA 练习3-4 统计字符

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 一、题目描述 ⭐️ 练习3-4 统计字符 本题要求编写程序&#xff0c;输入10个字符&#xff0c;统计其中英文字母、空格或回车、…...