未验证 提交 9ad273ab 编写于 作者: S Snailclimb 提交者: GitHub

Update ArrayList.md

上级 ae4f2acc
<!-- MarkdownTOC -->
- [ArrayList简介](#ArrayList简介)
- [ArrayList核心源码](#ArrayList核心源码)
- [ArrayList源码分析](#ArrayList源码分析)
- [ArrayList简介](#arraylist简介)
- [ArrayList核心源码](#arraylist核心源码)
- [ArrayList源码分析](#arraylist源码分析)
- [System.arraycopy\(\)和Arrays.copyOf\(\)方法](#systemarraycopy和arrayscopyof方法)
- [两者联系与区别](#两者联系与区别:)
- [ArrayList核心扩容技术](#ArrayList核心扩容技术)
- [两者联系与区别](#两者联系与区别)
- [ArrayList核心扩容技术](#arraylist核心扩容技术)
- [内部类](#内部类)
- [ArrayList经典Demo](#ArrayList经典demo)
- [ArrayList经典Demo](#arraylist经典demo)
<!-- /MarkdownTOC -->
### <font face="楷体" id="3"> ArrayList简介</font>
### <font face="楷体" id="3">ArrayList简介</font>
  ArrayList 的底层是数组队列,相当于<font color="red">动态数组</font>。与Java中的数组相比,它的容量能动态增长。在添加大量元素前,应用程序可以使用<font color="red">ensureCapacity </font>操作来增加 ArrayList 实例的容量。这可以减少递增式再分配的数量。它继承于**AbstractList**,实现了**List**, **RandomAccess**, **Cloneable**, **java.io.Serializable**这些接口。
  在我们学数据结构的时候就知道了线性表的顺序存储,插入删除元素的时间复杂度为**O(n)**,求表长以及增加元素,取第 i 元素的时间复杂度为**O(1)**
  ArrayList 继承了AbstractList,实现了List。它是一个数组队列,提供了相关的添加、删除、修改、遍历等功能。
......@@ -21,7 +21,7 @@
  ArrayList 实现了**Cloneable接口**,即覆盖了函数clone(),**能被克隆**
  ArrayList 实现**java.io.Serializable接口**,这意味着ArrayList**支持序列化****能通过序列化去传输**
  和Vector不同,**ArrayList中的操作不是线程安全的**!所以,建议在单线程中才使用ArrayList,而在多线程中可以选择Vector或者CopyOnWriteArrayList。
### <font face="楷体" id="4"> ArrayList核心源码</font>
### <font face="楷体" id="4">ArrayList核心源码</font>
```java
package java.util;
......@@ -557,7 +557,7 @@ public class ArrayList<E> extends AbstractList<E>
return Arrays.copyOf(elementData, size);
}
```
##### 两者联系与区别
##### 两者联系与区别
**联系:**
看两者源代码可以发现<font color="red">copyOf()</font>内部调用了<font color="red">System.arraycopy()</font>方法
**区别:**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册