ArrayList源码学习分析
2019-01-07 本文已影响3人
雨夏_
1.ArrayList简介
1.ArrayList继承AbstractList,并且实现了List接口。其实现方式底层就是一个数组,并且实现了增加、删除、修改、遍历等方法。
2.ArrayList相对于Vector来说,效率比Vector更高,但是线程不安全。
2.ArrayList的属性
data:image/s3,"s3://crabby-images/4c848/4c848e52c7996e87e0f14a304a531902b976f473" alt=""
3.ArrayList的构造方法
ArrayList有三种构造方法:
1.无参构造
data:image/s3,"s3://crabby-images/f0458/f0458919423def13726b39385b95ec68d426f94f" alt=""
2.初始化List的容量
data:image/s3,"s3://crabby-images/b7c11/b7c111a98168be21881aabf15fc2f0ccb973337b" alt=""
3.用一个Collection初始化List
data:image/s3,"s3://crabby-images/2c677/2c677d55cae8094e3f66a75ccf25ecdf31fb0593" alt=""
4.ArrayList的添加方法
1.添加元素
data:image/s3,"s3://crabby-images/89bd2/89bd230ff9560a3cfe5a49fa93b8825f6a197f13" alt=""
2.指定位置插入元素
data:image/s3,"s3://crabby-images/edea7/edea74c5ef11cdb394144421cd7f5085265ba035" alt=""
3.确认内部容量是否足够
data:image/s3,"s3://crabby-images/d5864/d58648f232081f04d3c6a31a0f58fc7c6f74f91b" alt=""
4.扩容
data:image/s3,"s3://crabby-images/69e05/69e05ef65321e2ac60106068611a66be2afb3706" alt=""
5.ArrayList的删除方法
1.根据index删除指定元素
data:image/s3,"s3://crabby-images/cf316/cf316034c303224febccf06b711c204066c40696" alt=""
2.根据传入的元素,进行遍历删除
data:image/s3,"s3://crabby-images/86136/861363e691f2ed918e2307adc1e6f65b286c4704" alt=""
6.ArrayList的修改方法
1.根据index修改
data:image/s3,"s3://crabby-images/5ed95/5ed95516a4be9f6689da171346f0303f343003f0" alt=""
7.ArrayList的查找方法
1.根据index查找
data:image/s3,"s3://crabby-images/a92e2/a92e28e1934a3807413bedfbfaa229c56e59eea4" alt=""
2.根据元素查找位置
data:image/s3,"s3://crabby-images/75619/75619ce2add9735473e0febfec4a69bcba8806e2" alt=""