Java容器:List
今天开始更新Java集合类相关博客,暂时打算分为List,Set,Map三个部分讲解,先出一个原型博客然后迭代更新(PS:依稀记得某些算法博客我也是这么说的然后原型写完就没后续了.......)。在讲最简单的List之前,先介绍下Collection接口的所有相关类的层次结构。
1. 集合类的层次关系
Java类的集合关系如图:

具体而言,Collection相关的类关系如下:
- Collection<--List<--Vector
- Collection<--List<--ArrayList
- Collection<--List<--LinkedList
- Collection<--Set<--HashSet
- Collection<--Set<--HashSet<--LinkedHashSet
- Collection<--Set<--SortedSet<--TreeSet
- Collection<--Queue
- Map<--SortedMap<--TreeMap
- Map<--HashMap
2. List接口简介
List是有序的Collection,有以下几个特性:
- 元素可以使用索引去访问,类似于Java的数组。
- 具有列表的功能,元素的顺序是按照添加的先后排序的。
- 允许重复元素和null元素。
3. List的常用方法
// C增:初始化,以ArrayList()为例
List list = new ArrayList();
// C增:向列表的尾部追加指定的元素
list.add("lwc");
// C增:在列表的指定位置插入指定元素
list.add(1, "nxj");
// C增:追加指定 collection 中的所有元素到此列表的结尾
list.addAll(new ArrayList());
// U更:用指定元素替换列表中指定位置的元素
list.set(0, "lp");
// R查:如果列表包含指定的元素,则返回true
list.contains("nxj");
// R查:如果列表包含指定 collection 的所有元素,则返回 true
list.containsAll(new ArrayList());
// R查:比较指定的对象与列表是否相等
list.equals(new ArrayList());
// R查:返回列表中指定位置的元素
list.get(0);
// R查:返回列表的哈希码值
list.hashCode();
// R查:返回列表中首次出现指定元素的索引,如果列表不包含此元素,则返回 -1
list.indexOf("lwc");
// R查:返回列表中最后出现指定元素的索引,如果列表不包含此元素,则返回 -1
list.lastIndexOf("lwc");
// R查:如果列表不包含元素,则返回 true
list.isEmpty();
// R查:返回包含列表中的所有元素的Object[]数组
list.toArray();
// R查:返回包含列表中所有元素的数组,可以用参数指定对象类型
list.toArray(new String[] { "a", "b" });
// R查:返回列表中的元素数
list.size();
// R查:返回列表中指定的fromIndex(包括)和toIndex(不包括)之间的视图,即其中内容仍为原List对象中内容,若更改会影响原List对象。
list.subList(1, 2);
// D删:移除列表中指定位置的元素
list.remove(0);
// D删:移除列表中出现的首个指定元素
list.remove("lwc");
// D删:从列表中移除指定 collection 中包含的所有元素
list.removeAll(new ArrayList());
// D删:从列表中移除所有元素
list.clear();
4. List实例
4.1. Vector
Vector是基于数组的List,相当于给数组添加了一些方便调用的功能。因此,它难以避免一些数组的限制,且性能也不会超过数组。Vector和ArrayList的区别是Vector中各方法是synchronized修饰的方法。而ArrayList中各方法没有synchronized修饰。因而,Vector是线程安全的而ArrayList不是,这也是它们最大的区别。
4.2. ArrayList
和Vector一样是基于数组的一种List结构,和Vector相比,由于其方法没有被synchronized修饰,因此有着更好的性能,但是在多线程环境下需要十分小心。
4.3. Vector和ArrayList的扩容
由于Vector和ArrayList是基于数组的,当数组的容量不够时(默认的初始容量是10,可以通过构造器自己设置),将会发生1.5倍扩容。易知如果扩容长度为2倍,那么新的数组无法利用扩容时释放的旧数组内存。当然,选择2倍在时间上要优于1.5倍。
4.4. LinkedList
不同于ArrayList和Vector,LinkedList如其名是不基于数组而是基于链接表的。因此,LinkedList的性能是不受数组限制的。LinkedList的节点构成如下:
private static class Node<E> {
E item;
Node<E> next;
Node<E> prev;
Node(Node<E> prev, E element, Node<E> next) {
this.item = element;
this.next = next;
this.prev = prev;
}
}
我们可以看到,LinkedList基于一个双向链接表,因此,当进行List中间位置的删除/添加工作时,LinkedList不会像ArrayList一样需要改动整个数组,仅仅对相关节点进行改动即可。但同时,在进行查询任务时,LinkedList的性能将劣于ArrayList。
5. 参考文章
Java容器:List的更多相关文章
- 【Java心得总结七】Java容器下——Map
我将容器类库自己平时编程及看书的感受总结成了三篇博文,前两篇分别是:[Java心得总结五]Java容器上——容器初探和[Java心得总结六]Java容器中——Collection,第一篇从宏观整体的角 ...
- 【Java心得总结六】Java容器中——Collection
在[Java心得总结五]Java容器上——容器初探这篇博文中,我对Java容器类库从一个整体的偏向于宏观的角度初步认识了Java容器类库.而在这篇博文中,我想着重对容器类库中的Collection容器 ...
- 【Java心得总结五】Java容器上——容器初探
在数学中我们有集合的概念,所谓的一个集合,就是将数个对象归类而分成为一个或数个形态各异的大小整体. 一般来讲,集合是具有某种特性的事物的整体,或是一些确认对象的汇集.构成集合的事物或对象称作元素或是成 ...
- Java 容器(list, set, map)
java容器类库的简化图: (虚线框表示接口, 实线框表示普通的类, 空心箭头表示特定的类实现了接口, 实心箭头表示某个类可以生成箭头所指的类对象) 继承Collection的主要有Set 和 Lis ...
- Java - 容器详解
一.ArrayList 长度可变数组,类似于c++ STL中的vector. 元素以线性方式连续存储,内部允许存放重复元素. 允许对元素进行随机的快速访问,但是向ArrayList中插入和删除元素的速 ...
- Java 容器:Collection 初探之 List
1 ///: JavaBasic//com.cnblogs.pattywgm.day1//CollectionTest.java 2 3 package com.cnblogs.pattywgm.da ...
- java容器---集合总结
思考为什么要引入容器这个概念? Java有多种方式保存对象(应该是对象的引用),例如使用数组时保存一组对象中的最有效的方式,如果你想保存一组基本类型的数据,也推荐使用这种方式,但大家知道数组是具有固定 ...
- 3)Java容器
3)Java容器 Java的集合框架核心主要有三种:List.Set和Map.这里的 Collection.List.Set和Map都是接口(Interface). List lst = new ...
- JAVA容器
JAVA容器 一.容器体系结构 java.util 二.迭代器Iterator<E> 迭代器是一种设计模式,可以遍历并选择序列中的对象,而开发人员并不需要了解该序列的底层结构.迭代器通常被 ...
- Java 容器相关知识全面总结
Java实用类库提供了一套相当完整的容器来帮助我们解决很多具体问题.因为我本身是一名Android开发者,包括我在内很多安卓开发,最拿手的就是ListView(RecycleView)+BaseAda ...
随机推荐
- 利用HTP工具包开发报表
利用这种方式的优点是不需要跑请求就可以打印报表 工具包中常用程序说明 htp.print 语法 htp.print (cbuf | dbuf | nbuf); 作用 generates a l ...
- Java进阶(二十七)使用Dom4j解析XML文件
使用Dom4j解析XML文件 写在前面的话 由于论文实验要求,需要实现操作XML文档,为此想到了dom4j这个工具,使用之后深感受益.在此分享给大家,以此共勉. 注:本文转载自http://blog. ...
- Mahout系列之----共轭梯度预处理
对于大型矩阵,预处理是很重要的.常用的预处理方法有: (1) 雅克比预处理 (2)块状雅克比预处理 (3)半LU 分解 (4)超松弛法
- Saiku去掉登录模块
1.修改applicationContext-saiku-webapp.xml <security:intercept-url pattern="/rest/**" acce ...
- android Google推荐的容器SparseArrayCompat简介
android Google推荐的容器SparseArrayCompat简介 private static SparseArrayCompat<BaseFragment> mCaches ...
- Android WebKit 内核
一.WebKit简介 WebKit是一个开源的浏览器网页排版引擎,包含WebCore排版引擎和JSCore引擎.WebCore和JSCore引擎来自于KDE项目的KHTML和KJS开源项目.Andro ...
- cocos2D v3.x中动作回调函数的变化
cocos2D v3.x版本中的动作的回调函数不能再带任何参数并且不能返回任何值. 官方给出的传递参数的办法是: 选择器(selector)不能带有任何形参,选择器需要的参数必须通过ivar或prop ...
- Android特效专辑(一)——水波纹过渡特效(首页)
Android特效专辑(一)--水波纹过渡特效(首页) 也是今天看到的一个特效,感觉挺漂亮的,最近也一直在筹划一个APP,就想把他当做APP的首页,然后加些处理,关于首页APP的特效等我完工了再贴出来 ...
- ZeroC Ice IceGrid Node和IceGrid
IceGrid Node介绍 绝大多数分布式系统都有一个共同特点,即分布在各个主机上的节点进程并不是完全独立的,而是彼此之间有相互联系和通信的.集群对集群中的节点有一些控制指令,如部署.启停或者调整某 ...
- JNI技术简介-android学习之旅(92)
分为5步 !!!注意本地方法是java中的方法,本地函数指的是c语言中的对应函数 1.在java类中声明本地方法 2.使用javah命令,生成包含jni本地函数原型的头文件 3. 实现jni本地函数 ...