码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java集合(二)


    目录

    1.List接口概述

    2.ArrayList的底层源码分析

    3.LinkedList的源码分析

    4.Vector的源码分析

    5.List接口中的常用方法


    1.List接口概述

    特点:

    1. 存储的元素都是有序的可重复的。
    2. 因为其有序和可重复性,我们通常用List接口的实现类来替换数组。

    具体实现类的特点

    1. ArrayList:①作为List接口的主要实现类。
    2. ②线程不安全的,效率较高。
    3. ③底层使用Object数组来进行存储
    4. LinkedList:①底层使用双向链表来进行存储。
    5. ②对于频繁的插入和删除操作效率比较高。
    6. Vector:①作为List接口的古老实现类,在Java1就已经存在了。
    7. ②线程安全的,效率较低。
    8. ③底层使用Object数组来进行存储。

    2.ArrayList的底层源码分析

    jdk7中的源码分析

    ①当使用空参构造器创建对象时,底层创建了一个长度为10的Object数组。

    ②添加数据时,先判断当前Object数组长度是否足够,如果长度足够则直接添加;如果长度不够则先将底层数组长度扩容为原来容量的1.5倍,同时将原有数组赋值给新数组。

    建议:因为当底层数组不够长时需要扩容,所以如果知道大概要存储多少数据,则建议使用带参构造器来指定底层数组的长度。

    jdk8中的源码分析

    ①使用空参构造器创建对象时,底层初始化为{}。

    ②在第一次调用add()方法时底层才创建长度为10的Object数组。

    ③后续添加数据同jdk7同样。

    jdk7中的ArrayList类似于单例模式中的饿汉式,jdk8中的类似于懒汉式,延迟了数组对象的创建,节省了内存。

    3.LinkedList的源码分析

    在LinkedList中定义了内部类Node,每个Node对象对应双链表中的一个节点。 

    4.Vector的源码分析

    除了在扩容时将容量变为原来容量的两倍之外其他和jdk7中ArrayList一样。 

    5.List接口中的常用方法

    1. add(int index,Object obj):向index位置插入obj对象。
    2. addAll(int index,Collection col):将col中的数据插入到指定位置 。
    3. get(int index):获取指定位置。
    4. indexOf(Object obj):返回当前对象在当前list对象中首次出现的索引。
    5. lastIndexOf(Object obj):返回最后一次出现的索引。
    6. Object remove(int index):将指定位置的元素删除,并返回。
    7. Object set(int index,Object obj):将指定位置的元素设置为obj,并返回。
    8. subList(int index,int endIndex):获取一个子List。
  • 相关阅读:
    XX攻击——反射型 XSS 攻击劫持用户浏览器
    416. 分割等和子集
    【2】SM2验签工具和RSA验签工具
    aspose转pdf乱码问题
    全域数据连接器解决运营痛点问题,助力海尔节省200万+
    VBA 将TXT的多行文本文件进行处理,以ID为单位处理成 一行
    JavaScript对象:我们真的需要模拟类吗?
    个人对JPA,mybatis,mybatisPlus的一点小小认知
    vue.config 同时配置 chainWebpack和关闭eslint检查多个配置项目共存
    谷粒商城 (十三) --------- 商品服务 API 三级分类 ④ 删除、新增分类
  • 原文地址:https://blog.csdn.net/m0_71987537/article/details/125473845
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号