【无标题】

  • 什么是ArrayList
  • ArrayList的特点
  • ArrayList继承的类和实现的接口
  • ArrayList的扩容
  • ArrayList的遍历

什么是Arraylist

Arraylist的底层是基于动态数组的形式实现的,通过加入元素的大小进行一个判断,不够的话就动态扩容

ArrayList的特点

访问的速度比较快,插入和删除的性能较差
支持null元素
有顺序
元素可以重复
线程不安全

ArrayList继承的类和实现的接口

在这里插入图片描述

ArrayList的扩容

通过无参构造方法对数组进行初始化,当数组进行第一次add时,会给数组分配一个默认的初始容量10,之后扩容会按照1.5增长
private Object[] grow(int minCapacity) {
int oldCapacity = elementData.length; if(oldCapacity>0||elementData!=DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
int newCapacity = ArraysSupport.newLength(oldCapacity,
minCapacity - oldCapacity, /* minimum growth /
oldCapacity >> 1 /
preferred growth */);
return elementData = Arrays.copyOf(elementData, newCapacity);
} else {
return elementData = new Object[Math.max(DEFAULT_CAPACITY, minCapacity)];
}
}

ArrayList的遍历

package com.pichen.basis.col;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class Test {

public static void main(String[] args) {
    List<Integer> list = new ArrayList<Integer>();
    for(int i = 0; i < 10; i++){
        list.add(i);
    }
    
    //直接打印
    System.out.println(list.toString());
    
    //for循环
    System.out.println("for循环:");
    for(int i = 0; i < list.size(); i++){
        System.out.print(list.get(i) + " ");
    }
    
    //foreach
    System.out.println("\nforeach:");
    for(Integer i : list){
        System.out.print(i + " ");
    }
    
    //iterator
    System.out.println("\niterator:");
    Iterator<Integer> iterator = list.iterator();
    while(iterator.hasNext()){
        System.out.print(iterator.next() + " ");
    }
}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值