Java容器面试知识点总结
容器
java容器有哪些?
String,数组以及Java.util 下面的集合类
List:存放有序,列表存储,元素可重复 ArrayList LinkedList Vector
Set:无序,元素不可重复 HashSet TreeSet
Map: 无序,元素可重复 HashMap TreeMap LinkedHashMap HashTable
Collection 和 Collections 有什么区别?
Collection 是集合类的一个顶级接口,它提供了对集合对象进行基本操作的通用接口方法。
Collections 是集合类的一个工具类,它提供了一系列得到静态方法,用于对集合中元素进行排序,搜索以及线程的同步等操作。
List,Set,Map 之间的区别是什么?
List : 可以允许重复的对象;可以插入多个null元素;有序,输入顺序就是输出顺序;
Set: 不允许重复对象;无序,且只允许一个null对象;
Map: 存储键值对,只能有唯一得到key,value 可以重复只能有一个null键
HashMap 和 Hashtable 有什么区别?
一,HashMap 可以接受null 键和值,HashTanble 不行
二,HashTable 是线程安全的,通过synchronized 来保证,而HashMap线程不安全
三,HashMap 的迭代器是fail-fast 迭代器,而HashTable的enumerator迭代器不上fail-fast.
如何决定使用HashMap 还是 TreeMap?
HashMap 基于散列表实现,适用于查询频繁的情况。
TreeMap 基于红黑树实现,适用于创建比较多的情况,且TreeMap 存储数据是按照字母表的顺序存储的,如果对顺序有要求也可以选用TreeMap。
说一下HashMap 的实现原理?
数组+链表,初始16 0.75 扩容,数据存在内部Map.Entry 中,其中包含key value hashcod 和 next.
说一下HashSet的实现原理?
HashSet 基于HashMap 实现,默认构造函数是构造一个初始容量为16的HashMap,所有放入HashSet集合的元素实际上由HashMAp De key来保存,而value 则保存了一个PRESENT 的静态Object对象,因为元素都保存在key中,所以才能不重复。
ArrayList 和 LinkedList的区别是什么?
- ArrayList 底层基于动态数组,LinkedList基于链表实现,底层是循环双向链表
- 对于随机访问get和set,ArrayList 优于LinkedList.
3.对于新增add和删除remove, LinkedList比较快。
如何实现数组和List之间的转换?
List 转数组:toArray()方法,在方法参数中指定原集合的长度数组即可,数组转为List用List:Arrays的asList()方法。
ArrayList 和 Vector 的区别是什么?
1.Vector 的 方法都是同步的,是线程安全的,ArrayList则不是。
2. 在进行扩容的时候,Vector扩容至原来的一倍,ArrayList增加至原来的0.5倍。
Array和ArrayList有何区别?
- Array(数组)可以包含基本数据类型和对象类型,ArrayList只能包含对象类型
- ArrayList 可以自动扩容,Array则不行
在!Queue 中 poll() 和 remove() 有什么区别?
queue 中,add方法和offer方法都可以添加元素,而remove和poll都是删除队列的头元素区别:add方法在队列满的情况下抛出异常,而offer方法则返回false。remove方法在队列为空时抛出异常,poll方法将返回null。
哪些集合类是线程安全的?
Vector HashTable ConcurrentHashMap Stack
迭代器 Iterator 是什么?
Iterator 是个接口,它提供了很多对元素进行迭代的方法。迭代器可以在迭代过程中删除底层集合的元素,可以直接调用Iterator的remover()方法来删除。
因为在Collection 接口中定义了获取集合迭代器的方法,所以每个集合都包含包括看可以返回迭代器实现的方法。
Iterator 怎么使用?有什么特点?
每个集合都可以用iterator() 方法一个Iterator实例,使用next() 方法获取序列中的下一个元素,使用hasNect() 方法检查序列中是否有元素,使用remove() 方法将迭代器新返回的方法删除,特点:Iterator将集合的遍历和底层的结构分离。
Iterator 和 ListIterator 有什么区别?
ListIterator 是 Iterator 的子接口,用于扩展 Iterator.
在 Iterator 中,我们只能向前移动,无法操纵或者修改集合中的元素.ListIterator 弥补了这种缺
点区别:
1.范围不同,Iterator 适用于所有集合,而 ListIterator 只适用于 List 及其子类
2.ListIterator 有 add 方法可以添加元素,Iterator 则不行.
3.ListIterator 可以实现双向遍历,Iterator 则不行.
4.ListIterator 可以实现对象的修改,Iterator 不行
5.ListIterator 可以获取集合中的所有,Iterator 不行.
怎么确保一个集合不能被修改?
可以使用 Collections 或者 Guava 来快速实现.如 Collections.unmodifiableMap(xxxMap);
希望大家点赞支持一下,小编才有动力继续更新!!!
相关文章:
Java容器面试知识点总结
容器 java容器有哪些? String,数组以及Java.util 下面的集合类 List:存放有序,列表存储,元素可重复 ArrayList LinkedList Vector Set:无序,元素不可重复 HashSet TreeSet Map: 无序,元素可重复…...
增长:2023 IT运维发展趋势前瞻
根据IDC和智研咨询数据等平台公开数据显示,从2018年至2022年,全球ITOM行业市场规模以8.58%的年均复合增长率高速增长。其中,中国ITOM市场在2020-2023年的年复合增长率为10.7%,到2023年市场规模将达到165.7亿元。012022中国IT运维解…...
自己定义typescript的类型声明文件xx.d.ts
****内容预警***菜鸟新手内容,大佬请绕道,不对的请指出我们在使用typescript的使用,如果安装一个包没有相应的类型声明文件,ts的类型检查就会报错,所以我们经常会安装npm包对应的types类型声明包,比如uuid …...
数据分析方法及名词解释总结_(面试2)
1、用户画像 1.1、什么是用户画像?如何构建用户画像? - 知乎提到用户画像, 很多人都可能存在的错误认知,即把用户画像简单理解成用户各种特征,比如说姓名、性别、…https://www.zhihu.com/question/372802348/answer/2…...
【FLY】Java知识点总结
目录认识Java概念图名词解释历史版本基础知识编程规范关键字数据类型运算符数组Stringequals与流程控制引用数据结构常用数据结构HashMapLinkedHashMapWeakHashMapIdentityHashMapEnumMapTreeMapCopyOnWriteArrayList面向对象类反射注解IO异常线程EffectiveJava8JVM运行时数据区…...
SpringMVC-0307
三、RequestMapping注解1、RequestMapping注解的功能从注解名称上我们可以看到,RequestMapping注解的作用就是将请求和处理请求的控制器方法关联起来,建立映射关系。SpringMVC 接收到指定的请求,就会来找到在映射关系中对应的控制器方法来处理…...
华为OD机试 - 九宫格按键输入(C 语言解题)【独家】
最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧文章目录 使用说明本期题目:九宫格按…...
Oracle 11g RAC群集部署
Oracle 11g RAC群集部署 1.环境介绍: 操作系统:Oracle Enterprise Linux 6.5 Oracle数据库:Oracle 11.2.0.4 集群软件:Oracle Grid Infrastructure 11.2.0.4 2.所需介质: p13390677_112040_Linux-x86-64_1of7 p133…...
【C++、C++11】列表初始化、右值引用
文章目录📖 前言1. 统一的列表初始化1.1 { } 花括号初始化:1.2 std::initializer_list:2. 右值引用2.1 什么是左值和右值:2.2 右值的分类:2.3 左值引用和右值引用的比较2.3 右值的使用场景:2.4 新的类功能&…...
CMU15-445 Project.3总结
在线测试 Project #3 - Query Execution 以下是Project #3的网址,2022FALL的Project #3是实现一个查询执行,实现一系列算子,用于实现数据库内的SQL计算。项目中的 Query Execution 主要分为三个任务: Access Method Executors…...
002+limou+HTML——(2)HTML文档
000、前言 一般来说一个静态网页拥有四种元素:文字、图片、超链接、音频和视频(注意,即使在web网页中植入Javascript语言,也不一定是动态网页,真正的动态网页判断标准:是否和服务器产生交互) …...
红外传感器模块与 Arduino 连接
红外传感器模块与 Arduino 连接 原文地址 Arduino 红外传感器接口 红外**接近传感器或红外传感器它发射红外光以感知周围环境,并可用于检测物体的运动。由于这是一个无源传感器,它只能测量红外辐射。如果您曾经尝试过设计避障机器人或任何其他基于接近…...
NC xml配置文件不能生产java文件
在NC开发过程中,新增、或修改了xml文件,在开发工具eclipse中生成或重新生成Java文件,发现生成不了相对应的Java文件。如下图,选中xml文件后,右键点击SpringXml to Java 这种情况其实一般都是xml配置文件有问题&#…...
华为OD机试 - 五键键盘(C 语言解题)【独家】
最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧文章目录 使用说明本期题目:五键键盘…...
Kubernetes Service简介
Service 之前我们了解了Pod的基本用法,我们也了解到Pod的生命是有限的,死亡过后不会复活了。我们后面学习到的RC和Deployment可以用来动态的创建和销毁Pod。尽管每个Pod都有自己的IP地址,但是如果Pod重新启动了的话那么他的IP很有可能也就变…...
【c++类与对象 】
目录:前言一、基础引入1.类的定义2.类的权限3.类的封装4.类的实例化5.计算类对象的大小结构体内存对齐规则空类的大小二、this指针this引入this指针的特性经典例题三、类的六个默认成员函数1、构造 && 析构构造函数析构函数2、拷贝 && 赋值拷贝构造…...
【C++】内联函数auto范围for循环nullptr
🏖️作者:malloc不出对象 ⛺专栏:C的学习之路 👦个人简介:一名双非本科院校大二在读的科班编程菜鸟,努力编程只为赶上各位大佬的步伐🙈🙈 目录前言一、内联函数1.1 内联函数概念1.2…...
运维效率狂飙,都在告警管理上
随着数字化进程的加速,企业IT设备和系统越来越多,告警和流程中断风险也随之增加。每套系统和工具发出的警报,听起来像是一场喧嚣的聚会,各自谈论不同的话题。更糟糕的是,安全和运维团队正在逐渐丧失对告警的敏感度&…...
【每日随笔】中国当前社会阶层 ( 技术无关 | 随便写写 )
文章目录一、阶层划分根据收入划分的阶层根据分工逻辑划分根据权利划分二、根据社会地位和掌握的资源划分的阶层三、赚钱的方式四、如何进入高阶层看了一个有意思的视频 , 讲的是中国当前的社会阶层 , 感觉好有道理 , 搜索了一些资料 ; 参考资料 : 关于中国的社会阶层社会在分…...
【13种css选择器】学css选择器,这一篇就够了
举例形象让你学会,不搞官方话css所有的选择器相邻兄弟选择器后续兄弟选择器后代选择器子代选择器并集选择器(多重选择器)属性选择器伪类选择器伪元素选择器class选择器(类选择器)id选择器*选择器(通配符选择器)标签选择…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
大数据学习栈记——Neo4j的安装与使用
本文介绍图数据库Neofj的安装与使用,操作系统:Ubuntu24.04,Neofj版本:2025.04.0。 Apt安装 Neofj可以进行官网安装:Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...
3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...
【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
质量体系的重要
质量体系是为确保产品、服务或过程质量满足规定要求,由相互关联的要素构成的有机整体。其核心内容可归纳为以下五个方面: 🏛️ 一、组织架构与职责 质量体系明确组织内各部门、岗位的职责与权限,形成层级清晰的管理网络…...
Swagger和OpenApi的前世今生
Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...
群晖NAS如何在虚拟机创建飞牛NAS
套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...
十九、【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建
【用户管理与权限 - 篇一】后端基础:用户列表与角色模型的初步构建 前言准备工作第一部分:回顾 Django 内置的 `User` 模型第二部分:设计并创建 `Role` 和 `UserProfile` 模型第三部分:创建 Serializers第四部分:创建 ViewSets第五部分:注册 API 路由第六部分:后端初步测…...
Python网页自动化Selenium中文文档
1. 安装 1.1. 安装 Selenium Python bindings 提供了一个简单的API,让你使用Selenium WebDriver来编写功能/校验测试。 通过Selenium Python的API,你可以非常直观的使用Selenium WebDriver的所有功能。 Selenium Python bindings 使用非常简洁方便的A…...
高防服务器价格高原因分析
高防服务器的价格较高,主要是由于其特殊的防御机制、硬件配置、运营维护等多方面的综合成本。以下从技术、资源和服务三个维度详细解析高防服务器昂贵的原因: 一、硬件与技术投入 大带宽需求 DDoS攻击通过占用大量带宽资源瘫痪目标服务器,因此…...
