码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 面试八股——集合——List


    主要问题

    数组

    如果数组索引从0开始时,数组的寻址方式为:

    如果数组索引从1开始时,数组的寻址方式为:

    此时对于CPU来说增加了一个减法指令,降低寻址效率。

    ArrayList⭐

    ArrayList构造函数

    尤其说一下第三个构造函数流程:首先判断参数c是否为ArrayList,若是则直接复制。若不是则将数据进行拷贝。

    ArrayList的底层实现原理

    总结一下:

    ArrayList初始容量为0,第一次添加数据会初始化容量为10。以后每当ArrayList进行扩容时,其长度会变为原先的1.5倍。

    其扩容过程如下:如果新插入一个数据后,首先判断当前ArrayList长度是否足够保存所有数据,如果不行的话就要进行扩容,ArrayList长度变为原先的1.5倍,随后将数据插入并返回成功布尔值。

    List与数组的相互转换
    数组转List

    通过Arrays.asList()或者 list.toList()[list可能为一个ArrayList对象]实现。二者区别是Arrays.asList修改原数组之后,List的数据也会改变,而list.toList()则不会改变。因为使用Arrays.asList后,新的List存储数据的数组地址指向的是原数组的地址,而ist.toList()是将原数组的数据拷贝一份到新的list中。

    LinkedList与ArrayList的区别

    1. 首先是底层的数据结构不同

    2. 效率问题(增删改查)

    3.空间占用

    4.线程安全

    二者都不是线程安全的。

  • 相关阅读:
    2022年中职组“网络安全”赛项湖南省任务书
    CAD如何转PDF?接下来分享这三个方法和操作步骤给你
    Javaweb的AJAX及Axios框架使用(封装AJAX)
    RAW图像详解及使用Python读取raw格式图像并显示
    Hbase TimeStamp的妙用
    heatmap | cell cycle genes in Seurat
    【微信小程序】swiper和swiper-item组件的基本使用
    1.5-11:整数的个数
    浅谈C++|多态篇
    【Unity入门计划】了解C#或Unity中的类和对象
  • 原文地址:https://blog.csdn.net/qq_45007794/article/details/137885907
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号