第2章 Java集合

news/2025/3/31 11:56:30/

2.1 谈谈你对Java集合的理解

难度:★★★

重点:★★★★

白话解析

集合类的概念还是比较重要的,不仅面试经常问,实际开发中也离不开。如果能把这道题真正理解了,集合可以说基本上没问题了。

集合就用来用存数据的,它提供了对数据增删改查和统计大小等方法。在Java中集合就两大类:Collection和Map,这两兄弟都是接口,规范了一些对数据操作的方法,但是他们自己不实现这些方法,而是由他们的子类去实现,这就好比,他们只制定规范,具体落地由其他人来做。

在理解具体的集合之前,我们要明白,集合是用来在内存中存数据的,而内存中存数据的基本结构无非就只有数组、链表、树、图等结构。搞明白这个,我们继续往下走。

在Collection接口下又定义了三个主要的子接口:Set、List、Queue;所以以后在被问到Java集合的时候,理解Set、List、Queue、Map这四兄弟就好了,那接下来为啥要有这四兄弟,简单做个介绍:

  • Set:按照源码的解释就是,它就是用来存不能出现重复的数据。

  • List:按照源码的解释,它是有序的集合,为什么说他有序呢?它会为每个数据给一个下标,标识该数据的唯一性,所以它里面可以存重复的。

  • Queue:从名字就能看出来,它就是一个队列,不过不算是基本结构,因为它底层真正用来存数据的依然是数组或者链表。然后通过基本数据结构疯转成队列这么一个结构,提供先进先出


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

相关文章

关于DNS

DNS DNS 域名解析系统DNS服务器如何能够承担高并发量? DNS 域名解析系统 上网,想要访问服务器,就需要知道服务器的IP地址,IP地址,是一串数字,虽然这个数字使用点分十进制已经清晰不少了,但是仍然不方便人们记忆和传播,因此,我们就使用单词来代替IP地址,使用baidu,sogou,bilib…

开发工具MobaXterm(终极终端)

MobaXterm 又名 MobaXVT,是一款增强型终端、X 服务器和 Unix 命令集(GNU/ Cygwin)工具箱。 常用SSH客户端介绍: SSH 为 Secure Shell 的缩写,是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用 SSH 协议可以有…

libpcap抓包编程范式

一、源码构建libpcap库 1. 下载源码 wget https://www.tcpdump.org/release/libpcap-1.10.4.tar.gz2. 解压 tar xf libpcap-1.10.4.tar.gz3. 编译 cd libpcap-1.10.4 ./configure --prefix/opt/libpcap-1.10.4 make sudo make install二、编程 1. 打开抓包口 pcap_t * pc…

子比主题v7.4绕授权接口源码

子比主题7.4绕授权接口源码,仅包含api文件仅供学习参考!正版子比主题7.4请到官方下载这里不提供。 使用方法: 1.搭建一个站点,绑定apizibl.com域名,并开启SSL (随便找个域名的证书就行) 2.上传以上源码,并配置好伪静…

PostgreSQL 查询某个属性相同内容出现的次数

查询某个数据库表属性 name 相同内容出现出现的次数,并按次数从大到小排序 SELECT name, COUNT(*) AS count FROM your_table GROUP BY name ORDER BY count DESC;示例 select project_id, COUNT(*) AS count from app_ads_positions group by project_id order b…

k8s Limits 限制内存

Limits 限制内存 在 Kubernetes (K8s) 中,可以使用 Limits(资源限制)来限制 Pod(容器)使用的内存数量。此处的 Limits 表示 Pod 在 K8s 集群中可用的最大内存量。一旦 Pod 内存使用超过这个限制,可能会触发…

算法 - 栈和队列

算法 - 栈和队列 算法 - 栈和队列 栈 1. 数组实现2. 链表实现 队列 栈 public interface MyStack<Item> extends Iterable<Item> {MyStack<Item> push(Item item);Item pop() throws Exception;boolean isEmpty();int size();}1. 数组实现 public class A…

经典题记录 字符串相加/相乘

1. LeetCode 415 字符串相加 代码一&#xff1a;代码简短&#xff0c;但需要借助额外的一个string来保存结果&#xff0c;更占用内存。 class Solution { public:string addStrings(string num1, string num2) {string ans"";int size1num1.size();int size2num2.si…