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

JavaSE知识总结(集合篇) ~个人笔记以及不断思考~持续更新

目录

集合

List

List的各种接口API

List的五种遍历方式

List的删除是内部是怎么做的?

ArrayList和LinkedList的区别

Vetor和Stack是什么?

Set

Set的特点

HashSet

TreeSet

LinkedHashSet

Map

HashMap

LinkedHashMap

TreeMap


集合

在Java中,集合分为单列集合和双列集合(也叫映射集合),单列集合接口主要有:List,Set。

双列集合(映射集合)主要有:Map

List

List是Collection的子接口,是java.util提供的,里面提供了很多的实现类,比如ArrayList,LinkedList,Vetor、Stack。

List的各种接口API

添加list.add

查找list.get

删除list.remove

修改list.set

List的五种遍历方式

迭代器遍历:可用于删除元素

List<String> list = new ArrayList<>();
list.add("Apple");
list.add("Banana");
list.add("Cherry");Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {String fruit = iterator.next();System.out.println(fruit);
}

列表迭代器:用于添加元素

List<String> list = new ArrayList<>();
list.add("Apple");
list.add("Banana");
list.add("Cherry");ListIterator<String> listIterator = list.listIterator();
while (listIterator.hasNext()) {String fruit = listIterator.next();System.out.println(fruit);
}while (listIterator.hasPrevious()) {String fruit = listIterator.previous();System.out.println(fruit);
}

for循环

增强for循环

Lambda迭代器

List的删除是内部是怎么做的?

ArrayList的删除:如果删除第一个和中间的,会使其他的元素向前移动,然后调整数组大小,如果删除最后一个只需要调整大小即可

LinkedList的删除:如果删除第一个改变头节点,如果删除中间的就把上一个节点指向下一个节点就可以,如果删除最后一个只需更新尾节点的前一个节点,然后将尾节点的引用置空。

ArrayList和LinkedList的区别

ArrayList底层是动态数组,内存是连续的,创建时候其实是空参创建的,当添加第一个元素的时候,他会初始化10个容量,当满了的时候会扩大1.5倍。ArrayList查询快。因为是数组有索引内存连续 常数时间复杂度o(1) 但是删除线性时间复杂度为O(n) 因为删除过程麻烦。

ps:ArrayList的扩容是属于重新建了一个数组

ListedList的底层是一个双向链表,它有一些独特的API,查找慢,因为需要遍历整个链表,但是插入和删除快,因为插入的话直接插入节点就可以。

  1. 添加元素

    • add(E e):在链表末尾添加元素。
    • add(int index, E element):在指定位置插入元素。
    • addFirst(E e):在链表头部添加元素。
    • addLast(E e):在链表尾部添加元素。
  2. 删除元素

    • remove(int index):删除指定位置的元素。
    • remove(Object o):删除第一个匹配的元素。
    • removeFirst():删除链表头部的元素。
    • removeLast():删除链表尾部的元素。
  3. 获取元素

    • get(int index):获取指定位置的元素。
    • getFirst():获取链表头部的元素。
    • getLast():获取链表尾部的元素。

Vetor和Stack是什么?

Vetor是ArrayList的线程安全版本,使用Sychronized实现的,Stack是一种后进先出的数据结构。

Set

Set的特点

Set的特点就是无序、不重复,无索引。实现类有Hashset、TreeSet、LinkedHashSet。

HashSet

HashSet是用哈希表存储数据的,无序、不重复、无索引,通过哈希函数去计算并映射到哈希表的位置上面 (可能出现哈希碰撞)。增删改都是O(1)

TreeSet

基于红黑树去实现的,特点是无索引,不重复,可排序,增删改是O(logn)

LinkedHashSet

双向链表+哈希表,有序不重复无索引,增删改查都是o(1)因为增删改是用双向链表而查找是用哈希表。

Map

Map的实现类有HashMap、TreeMap、LinkedHashMap。

HashMap

LinkedHashMap

TreeMap


文章转载自:

http://upZdMcGP.zdhjb.cn
http://cdsQWxim.zdhjb.cn
http://fO9EiqQt.zdhjb.cn
http://CQLY6UC6.zdhjb.cn
http://ATnxm2kw.zdhjb.cn
http://wIqChkhL.zdhjb.cn
http://MfdcyGLK.zdhjb.cn
http://5nsWq3HZ.zdhjb.cn
http://tUBImXXq.zdhjb.cn
http://u50MB2FT.zdhjb.cn
http://drO2wKZi.zdhjb.cn
http://dMz88tb1.zdhjb.cn
http://RforVFlk.zdhjb.cn
http://Ef3TwQ3t.zdhjb.cn
http://2D2AVR0X.zdhjb.cn
http://4YeLH1iA.zdhjb.cn
http://arGaCxBw.zdhjb.cn
http://9SJAWqHB.zdhjb.cn
http://EvPEW6SH.zdhjb.cn
http://7n8KXLTt.zdhjb.cn
http://kpcC72bC.zdhjb.cn
http://p8cM4up2.zdhjb.cn
http://uuBcjKbF.zdhjb.cn
http://MdeaIu10.zdhjb.cn
http://T24aea2f.zdhjb.cn
http://6aEhnSm9.zdhjb.cn
http://3SCotJkw.zdhjb.cn
http://Ovf6GeNA.zdhjb.cn
http://p8FSSqEw.zdhjb.cn
http://5wuyeu4Y.zdhjb.cn
http://www.dtcms.com/a/227091.html

相关文章:

  • 学习经验分享【40】目标检测热力图制作
  • [HTML5]快速掌握canvas
  • (Python网络爬虫);抓取B站404页面小漫画
  • 智慧零工平台前端开发实战:从uni-app到跨平台应用
  • uniapp路由跳转toolbar页面
  • 通俗易懂解析:@ComponentScan 与 @MapperScan 的异同与用法
  • Java连接Redis和基础操作命令
  • 微软markitdown PDF/WORD/HTML文档转Markdown格式软件整合包下载
  • GODOT引擎学习日志
  • Gartner《Emerging Patterns for Building LLM-Based AIAgents》学习心得
  • 线程间和进程间是如何进行通信
  • 复变函数 $w = z^2$ 的映射图像演示
  • 端到端的导航技术NeuPAN论文讲解
  • 《AI Agent项目开发实战》DeepSeek R1模型蒸馏入门实战
  • 达梦数据库 Windows 系统安装教程
  • HTML 中 class 属性介绍、用法
  • 【学习笔记】On the Biology of a Large Language Model
  • ffmpeg 的视频格式转换 c# win10
  • 使用免费wordpress成品网站模板需要注意点什么
  • 【SpringBoot】| 接口架构风格—RESTful
  • opencv调用模型
  • 交换机、路由器配置
  • Oracle expdp过滤部分表数据
  • Python编程基础(三) | 操作列表
  • ESP32与STM32
  • 【MIMO稳定裕度】基于数据驱动的多输入多输出系统稳定裕度分析
  • ps曝光度调整
  • 408考研逐题详解:2009年第27题
  • 【笔记】Windows 下载并安装 ChromeDriver
  • SpringBoot(六)--- AOP、ThreadLocal