源码(04) -- java.util.List<E>
java.util.List<E> 源码分析(JDK1.7)
---------------------------------------------------------------------------------
java.util.List<E>是一个接口,它的定义如下:
public interface List<E> extends Collection<E> {
// Query Operations
// Modification Operations
// Bulk Modification Operations
// Comparison and hashing
// Positional Access Operations
// Search Operations
// List Iterators
// View
}
(1)List列表是一个有序的collection,此接口可以对列表中每个元素的插入位置进行精确地控制
(2)用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索List列表中的元素
(3)List列表允许重复的元素
(4)List接口提供了特殊的迭代器,称为ListIterator,除了允许Iterator接口提供的正常操作外,该迭代器还允许元素插入和替换,以及双向访问
(5)看看java.util.Collection<E>的源码介绍
---------------------------------------------------------------------------------
下面来看看java.util.List<E>中具体有哪些方法:
从下面的表格中可以看出java.util.List<E>接口中一共有25个方法:
其中查询操作6个;修改操作2个;批量操作6个;比较和哈希操作2个;位置访问操作4个;位置查询操作2个;List Iterator操作2个;视图操作1个;(用浅蓝色字体标出的是java.util.List<E>接口新增的方法,其余的都是从java.util.Collection<E>中来的。 (~_~ 真是不嫌事情多,提供了25个方法需要由其扩展类来实现...))
| 查询操作 | int size() | 返回列表中的元素数。如果列表包含多于Integer.MAX_VALUE个元素,则返回Integer.MAX_VALUE |
| boolean isEmpty() | 如果列表不包含元素,则返回true | |
| boolean contains(Object o) | 如果列表包含指定的元素,则返回true。 | |
| Iterator<E> iterator() | 返回按适当顺序在列表的元素上进行迭代的迭代器 | |
| Object[] toArray() | 返回按适当顺序包含列表中的所有元素的数组 | |
| <T> T[] toArray(T[] a) | 返回按适当顺序包含列表中所有元素的数组 | |
| 修改操作 | boolean add(E e) | 向列表的尾部添加指定的元素 |
| boolean remove(Object o) | 从此列表中移除第一次出现的指定元素 | |
| 批量操作 | boolean containsAll(Collection<?> c) | 如果列表包含指定collection的所有元素,则返回true |
| boolean addAll(Collection<? extends E> c) | 添加指定collection中的所有元素到此列表的结尾 | |
| boolean addAll(int index,Collection<? extends E> c) | 将指定collection中的所有元素都插入到列表中的指定位置 | |
| boolean removeAll(Collection<?> c) | 从列表中移除指定collection中包含的其所有元素 | |
| boolean retainAll(Collection<?> c) | 仅在列表中保留指定collection中所包含的元素 | |
| void clear() | 从列表中移除所有元素 | |
| 比较和哈希操作 | boolean equals(Object o) | 比较指定的对象与列表是否相等 |
| int hashCode() | 返回列表的哈希码值 | |
| 位置访问操作 | E get(int index) | 返回列表中指定位置的元素 |
| E set(int index,E element) | 用指定元素替换列表中指定位置的元素 | |
| void add(int index,E element) | 在列表的指定位置插入指定元素 | |
| E remove(int index) | 移除列表中指定位置的元素 | |
| 位置查询操作 | int indexOf(Object o) | 返回此列表中第一次出现的指定元素的索引 |
| int lastIndexOf(Object o) | 返回此列表中最后出现的指定元素的索引 | |
| List Iterators | ListIterator<E> listIterator() | 返回此列表元素的列表迭代器 |
| ListIterator<E> listIterator(int index) | 返回列表中元素的列表迭代器 | |
| 视图操作 | List<E> subList(int fromIndex,int toIndex) | 返回列表中指定的fromIndex(包括)和toIndex(不包括)之间的部分视图 |
再来看看下图:

---------------------------------------------------------------------------------
java.util.List<E>源码如下:(看看下面的源码,定义的很规范,各种操作都有-----> 此时应该想到它的实现类该有多可怜,要实现多少方法呀。~_~)
package java.util;
public interface List<E> extends Collection<E> {
// Query Operations
int size();
boolean isEmpty();
boolean contains(Object o);
Iterator<E> iterator();
Object[] toArray();
<T> T[] toArray(T[] a);
// Modification Operations
boolean add(E e);
boolean remove(Object o);
// Bulk Modification Operations
boolean containsAll(Collection<?> c);
boolean addAll(Collection<? extends E> c);
boolean addAll(int index, Collection<? extends E> c);
boolean removeAll(Collection<?> c);
boolean retainAll(Collection<?> c);
void clear();
// Comparison and hashing
boolean equals(Object o);
int hashCode();
// Positional Access Operations
E get(int index);
E set(int index, E element);
void add(int index, E element);
E remove(int index);
// Search Operations
int indexOf(Object o);
int lastIndexOf(Object o);
// List Iterators
ListIterator<E> listIterator();
ListIterator<E> listIterator(int index);
// View
List<E> subList(int fromIndex, int toIndex);
}
---------------------------------------------------------------------------------
---------------------------------------------------------------------------------
---------------------------------------------------------------------------------
---------------------------------------------------------------------------------
源码(04) -- java.util.List<E>的更多相关文章
- 源码(09) -- java.util.Arrays
java.util.Arrays 源码分析 ------------------------------------------------------------------------------ ...
- 源码(03) -- java.util.Collection<E>
java.util.Collection<E> 源码分析(JDK1.7) -------------------------------------------------------- ...
- JDK1.8源码(五)——java.util.Vector类
JDK1.8源码(五)--java.lang. https://www.cnblogs.com/IT-CPC/p/10897559.html
- Java源码之 java.util.concurrent 学习笔记01
准备花点时间看看 java.util.concurrent这个包的源代码,来提高自己对Java的认识,努力~~~ 参阅了@梧留柒的博客!边看源码,边通过前辈的博客学习! 包下的代码结构分类: 1.ja ...
- 源码(05) -- java.util.AbstractCollection<E>
java.util.AbstractCollection<E> 源码分析(JDK1.7) ------------------------------------------------- ...
- 源码(06) -- java.util.AbstractList<E>
java.util.AbstractList<E> 源码分析(JDK1.7) ------------------------------------------------------- ...
- 源码(07) -- java.util.Iterator<E>
java.util.Iterator<E> 源码分析(JDK1.7) ----------------------------------------------------------- ...
- 源码(08) -- java.util.ListIterator<E>
java.util.ListIterator<E> 源码分析(JDK1.7) ------------------------------------------------------- ...
- JDK1.8源码(四)——java.util.Arrays 类
java.util.Arrays 类是 JDK 提供的一个工具类,用来处理数组的各种方法,而且每个方法基本上都是静态方法,能直接通过类名Arrays调用. 1.asList public static ...
随机推荐
- sersync 实时同步文件
sersync 主要用于服务器同步,web镜像等功能.sersync是使用c++编写,在结合rsync同步的时候,节省了运行时耗和网络资源.因此更快.sersync配置起来很简单.另外本项目相比较其他 ...
- 15、手把手教你Extjs5(十五)各种Grid列的自定义渲染
Grid各列已经能够展示出来了.列的类型包括字符型,整型,浮点型,货币型,百分比型,日期型和布尔型,我自定义了各种类型的渲染样式: 1.整型:标题栏居中,数值靠右显示,正数颜色为蓝色,负数颜色为红色, ...
- VS2010 中 error 2732: 链接规范与的早期规范冲突 的解决
在实验室做项目的时候遇到了这个问题,终于整明白了. 一般来说这个错误出现在类似以下的语句中 extern "C" int yylex(void); extern "C&q ...
- S3C2440 ADC详解
S3C2440拥有八通道的十位ADC, 最大转换率为2.5MHz A/D转换器时钟下的500KSPS.A/D转换器支持片上采样-保持功能和掉电模式的操作. 八个通道中有四个通道适用于电阻屏的触摸屏触摸 ...
- Unity3D ——强大的跨平台3D游戏开发工具(五)
第九章 图形用户界面类G.U.I 您在玩很多3D游戏的时候,不知是否注意到在游戏界面中,总有一些图形和文字信息是不随着3D视角的改变而改变的.这也是由于游戏本身的要求而决定的.比如说英雄的生命值,聊天 ...
- HTML段落自动换行的样式设置
在HTML的P标记中,默认情况下是自动换行的. 如果你的段落是由中文字符或者英文单词组成的,这基本没什么问题.但是如果你的段落是由不间断的英文字母(浏览器会认为是一个单词)组成,则默认情况下不会换行, ...
- .net中的4种事务总结
在 一个MIS系统中,没有用事务那就绝对是有问题的,要么就只有一种情况:你的系统实在是太小了,业务业务逻辑有只要一步执行就可以完成了.因此掌握事务处 理的方法是很重要,进我的归类在.net中大致有以下 ...
- CentOS6.5编译安装Redis
一.首先要检测是否安装gcc yum install gcc-c++ yum install -y tcl 进入redis目录 cd /usr/local/redis .编译安装 make make ...
- JAVA WEB 中的编码分析
JAVA WEB 中的编码分析 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-co ...
- ZOJ 1011 - NTA
题目大意:有一颗完全二叉树,给节点一个信号会从一个表中选择一对信号分别传递给两个子节点.最后判断所有叶子节点是否满足给定的规则.题目有点长,具体可参见原题. 首先是表格中数据的存储,由于会有多个元素, ...