解析字节算法面试真题,深入探究ArrayList应用原理

ArrayList是Java的链表类,作为Java三大容器组成之一的List的组成部分,如下图所示

解析字节算法面试真题,深入探究ArrayList应用原理

在项目开发中常用,虽然他有一些不足的地方,但是这不足以替代他帮助程序员解决大量问题的光辉,正是由于他被经常使用,所以在面试的时候也被经常问到,比方说字节、腾讯这一类对于算法实现以及源码考察比较重视的公司更是如此,今天我就通过几道面试题,以面试的身份对于ArrayList进行讲解

关注公众号:Java架构师联盟,每日更新技术好文

题目:【java源码】ArrayList

ArrayList 常用功能:构造函数、增、批量增、删、批量删、批量保留
ArrayList 属性:
// 默认数组长度(数组,而不是数据个数)
private static final int DEFAULT_CAPACITY = 10;
// 空数据
private static final Object[] EMPTY_ELEMENTDATA = {};
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
// 实际用于存放数据的地方
transient Object[] elementData;
// 数据个数
private int size;

**ArrayList 常用功能:**构造函数、增、批量增、删、批量删、批量保留
ArrayList 属性:

    // 默认数组长度(数组,而不是数据个数)
    private static final int DEFAULT_CAPACITY = 10;
    // 空数据
    private static final Object[] EMPTY_ELEMENTDATA = {};
    private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
    // 实际用于存放数据的地方
    transient Object[] elementData;
    // 数据个数
    private int size;

1、构造函数

    ①public ArrayList();
        只干了一件事:this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
    ②public ArrayList(int initialCapacity);
        指定初始化elementData数组的初始大小。this.elementData = new Object[initialCapacity];
    ③public ArrayList(Collection<? extends E> c) {
        elementData = c.toArray();
        if ((size = elementData.length) != 0) {
            // c.toArray might (incorrectly) not return Object[] (see 6260652)
            if (elementData.getClass() != Object[].class)
                elementData = Arrays.copyOf(elementData, size, Object[].class);
        } else {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值