博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
唠唠SE的集合-04——ArrayList
阅读量:6112 次
发布时间:2019-06-21

本文共 926 字,大约阅读时间需要 3 分钟。

hot3.png

4. ArrayList(使用频率最高)

底层数据结构是数组查询快,增删慢;线程不安全,效率高

数组为什么是查询快?因为数组的内存空间地址是连续的。

        ArrayList底层维护了一个Object[] 用于存储对象,默认数组的长度是10。

可以通过 new ArrayList(20)显式的指定用于存储对象的数组的长度。

当默认的或者指定的容量不够存储对象的时候,容量自动增长为原来的容量的1.5倍。

由于ArrayList是数组实现,在添加元素的时候会牵扯到数组增容,以及拷贝元素,所以慢。数组是可以直接按索引查找,所以查找时较快。

 

我们来举一个栗子:

import java.util.ArrayList;import java.util.Iterator;public class Test {    public static void main(String[] args) {        ArrayList
list = new ArrayList<>(); list.add("abc"); list.add("def"); list.add("abc"); list.add("abc"); list.add("ert"); list.add("qaz"); Iterator
iterator = list.iterator(); while (iterator.hasNext()) { if (iterator.next().equals("abc")) { iterator.remove(); // 不能用list.remove,会引起异常 } } System.out.println(list); }}

转载于:https://my.oschina.net/LinkedBear/blog/1615346

你可能感兴趣的文章
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
转:Vue keep-alive实践总结
查看>>
android studio修改新项目package名称
查看>>
深入python的set和dict
查看>>
C++ 11 lambda
查看>>
Hadoop2.5.0 搭建实录
查看>>
实验吧 recursive write up
查看>>
High-speed Charting Control--MFC绘制图表(折线图、饼图、柱形图)控件
查看>>
go test命令參数问题
查看>>
linux 搜索文本
查看>>
超实用Mac软件分享(二)
查看>>