JAVA基础知识之List集合
- List接口和ListIterator接口介绍
- List集合新增方法
- List集合判断元素重复的标准
- ListIterator
- List.ArrayList和List.Vector
- 固定长度的List
List接口和ListIterator接口介绍
List是一种元素有序,可重复的集合。默认是按元素插入顺序排序。可以像数组一样按照索引来访问元素。因此List接口提供了除Collection接口方法之外的额外方法,它们都是按索引来访问元素,
List集合新增方法
void add(int index, Object element)
boolean addAll(int index, Colection c); 将集合C的所有元素都插入到List集合的index索引处。
void get(int index)
int indexOf(Object o); 返回对象O在集合第一次出现的索引
int lastOf(Object o);
Object remove(int index):删除并返回集合在index索引处的元素
Object set(int index, Object element):替换元素
List subList(int fromIndex, in toIndex); 返回从索引fromInddex到toIndex的子集合,这是List集合独有的方法。
void replaceAll(UnaryOperator operator):这个看不懂。。。
voidd sort(Comparator c):根据Comparator规则对集合元素排序
List集合判断元素重复的标准
List判断两个元素相等的方法是,只要equals返回true即相等,下面是一个例子。
package collection.List; import java.util.ArrayList;
import java.util.List; class A {
public boolean equals(Object obj) {
return true;
}
} public class Lists {
public static void main(String[] args) {
List books = new ArrayList();
books.add("book1");
books.add("book2");
books.add("book3");
System.out.println(books);
books.remove(new A());
System.out.println(books);
books.remove(new A());
System.out.println(books);
}
}
可以看到,每次执行books.remove(new A());的时候,都调用A类重写额equals,每次都返回true,因此每次在遍历books集合第一个元素的时候做对比的时候就返回了true,因此每次都会删除books集合第一个元素,执行结果如下,
[book1, book2, book3]
[book2, book3]
[book3]
ListIterator
ListIterator是List集合特有的方法, ListIterator接口是Iterator的子接口,除了提供基本的hasNext, next, remove方法外,还提供了额外的向前迭代和添加元素的方法,值得注意的是,必须先向后迭代之后,再向前迭代才有意义,否则就不会有结果输出。
boolean hasPrevious():是否有上一个元素。 (对应 hasNext方法)
Object previous(); 返回上一个元素(对应next方法)
void add(Object o) 添加一个元素(对应remove方法)
下面举例说明ListIterator的用法
package collection.List; import java.util.List;
import java.util.ArrayList;
import java.util.ListIterator; public class ListIterators {
public static void main(String[] args) {
String[] books = {"book1","book2","book3","book4"};
List bookList = new ArrayList();
for(int i=0; i<books.length; i++) {
bookList.add(books[i]);
} ListIterator lit = bookList.listIterator();
while(lit.hasNext()) {
System.out.println(lit.next());
System.out.println("------------------------");
} System.out.println("开始反向迭代");
while(lit.hasPrevious()) {
System.out.println(lit.previous());
System.out.println("------------------------");
} }
}
执行结果,
book1
------------------------
book2
------------------------
book3
------------------------
book4
------------------------
开始反向迭代
book4
------------------------
book3
------------------------
book2
------------------------
book1
------------------------
List.ArrayList和List.Vector
List.ArrayList和List.Vector是List接口的两个典型的实现类。ListArray底层其实就是封装了一个数组来保存元素,这个数组的容量允许扩展。这个数组的有一个初始容量initialCapacity(默认为10),当新元素插入ArrayList时,此数组容量会自动增加;而当需要插入大量元素时候,可以通过ensureCapacity(int i)这个方法增加足够的容量,从而减少多次分配内存空间的次数。下面是JDK1.7源码中,ArrayList的代码,
//JDK源码, ArrayList
...
public boolean add(Object obj)
{
ensureCapacityInternal(size + 1);
elementData[size++] = obj;
return true;
}
...
private transient Object elementData[];
可见一个ArrayList底层其实就是封装了一个Object类型的数组elementData。
Vector和ArrayList的功能大体相同,只是ArrayList是线程非安全,而Vector是线程安全的,而且Vector非常古老,在JAVA集合框架出来之前就有了,所以从多方面来说,Vector的性能是比不上ArraryList的,因此通常情况下推荐用ArrayList.
ArrayList和Vector提供了两个重新分配Object数组的方法,即ensureCapacity(int i),扩展i个空间。 void trimToSize(), 清理集合多占用的空间(即将容量减小到实际元素的个数)
Vector还提供了一个子类Stack, 即一个遵循LIFO的栈容器。提供了以下方法:Object peek(), 获取栈顶元素。 Object pop() 出栈, void push(Object item) 入栈。
固定长度的List (Arrays类中的内部类ArrayList)
上面介绍的ArrayList是List接口的一个实现类, 此外,通过数组工具Arrays的asList()方法,可以返回一个Arrays工具内部类ArrayList的实例对象。而这个ArrayList是一个固定长度的List集合,程序只能遍历数组,不能增加,删除数组元素,否则会抛出异常。下面是JDK 1.7源码Arrays中ArrayList的源码
public class Arrays
{
private static class ArrayList extends AbstractList
implements RandomAccess, Serializable
{ public int size()
{
return a.length;
} ......
从JDK源码中可以看到,根本就没有定义成动态数组,即Arrays工具类中的ArrayList长度是不可变的,即不可用添加(add)元素,也不可以删除(remove)元素,如下例子,
package collection.List; import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator; public class FixeSizeList {
public static void main(String[] args) {
Integer[] varI = new Integer[] {9,5,5,-3,2};
List fixeList = Arrays.asList(varI);
System.out.println(fixeList.getClass());
//会按照插入顺序打印出来
System.out.println(fixeList);
ListIterator lit = fixeList.listIterator();
while(lit.hasNext()) {
System.out.print(lit.next()+",");
}
System.out.println("\n==================");
for(int i=0; i<varI.length; i++) {
System.out.print(fixeList.get(i)+",");
}
System.out.println("\n==================");
lit.hasNext();
//lit.remove();
lit.hasPrevious();
//lit.add(new Integer(2));
//fixeList.remove(new Integer(2));
//fixeList.add(new Integer(2));
}
}
如果取消上面的注释,将会抛出错误,如下面的结果。
class java.util.Arrays$ArrayList
[9, 5, 5, -3, 2]
9,5,5,-3,2,
==================
9,5,5,-3,2,
==================
Exception in thread "main" java.lang.UnsupportedOperationException
at java.util.AbstractList.remove(Unknown Source)
at java.util.AbstractList$Itr.remove(Unknown Source)
at collection.List.FixeSizeList.main(FixeSizeList.java:28)
JAVA基础知识之List集合的更多相关文章
- Java基础知识强化之集合框架笔记76:ConcurrentHashMap之 ConcurrentHashMap简介
1. ConcurrentHashMap简介: ConcurrentHashMap是一个线程安全的Hash Table,它的主要功能是提供了一组和Hashtable功能相同但是线程安全的方法.Conc ...
- Java基础知识强化之集合框架笔记39:Set集合之HashSet存储字符串并遍历
1. HashSet类的概述: (1)不保证set的迭代顺序 (2)特别是它不保证该顺序恒久不变 HashSet底层数据结构是哈希表,哈希表依赖于哈希值存储,通过哈希值来确定元素的位置, 而保证元素 ...
- Java基础知识强化之集合框架笔记27:ArrayList集合练习之去除ArrayList集合中的重复字符串元素
1. 去除ArrayList集合中的重复字符串元素(字符串内容相同) 分析: (1)创建集合对象 (2)添加多个字符串元素(包含重复的) (3)创建新的集合 (4)遍历旧集合,获取得到每一个元素 (5 ...
- Java基础知识强化之集合框架笔记07:Collection集合的遍历之迭代器遍历
1. Collection的迭代器: Iterator iterator():迭代器,集合的专用遍历方式 2. 代码示例: package cn.itcast_03; import java.util ...
- Java基础知识强化之集合框架笔记05:Collection集合的遍历
1.Collection集合的遍历 Collection集合直接是不能遍历的,所以我们要间接方式才能遍历,我们知道数组Array方便实现变量,我们可以这样: 使用Object[] toArray() ...
- Java基础知识强化之集合框架笔记65:Map集合之集合多层嵌套的数据分析
1. 为了更符合要求: 这次的数据就看成是学生对象. 传智播客 bj 北京校区 jc 基础班 林青霞 27 风清扬 30 jy 就业班 赵雅芝 28 武鑫 29 sh 上海 ...
- Java基础知识强化之集合框架笔记62:Map集合之HashMap嵌套HashMap
1. HashMap嵌套HashMap 传智播客 jc 基础班 陈玉楼 20 高跃 ...
- Java基础知识强化之集合框架笔记04:Collection集合的基本功能测试
1. Collection集合的基本功能测试: package cn.itcast_01; import java.util.ArrayList; import java.util.Collectio ...
- Java基础知识强化之集合框架笔记01:集合的由来与数组的区别
1. 集合的由来: 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储.而要想存储多个对象,就不能是一个基本的变量,而应该 ...
- Java基础知识回顾之四 ----- 集合List、Map和Set
前言 在上一篇中回顾了Java的三大特性:封装.继承和多态.本篇则来介绍下集合. 集合介绍 我们在进行Java程序开发的时候,除了最常用的基础数据类型和String对象外,也经常会用到集合相关类. 集 ...
随机推荐
- 《数据结构与算法分析:C语言描述_原书第二版》CH3表、栈和队列_reading notes
表.栈和队列是最简单和最基本的三种数据结构.基本上,每一个有意义的程序都将明晰地至少使用一种这样的数据结构,比如栈在程序中总是要间接地用到,不管你在程序中是否做了声明. 本章学习重点: 理解抽象数据类 ...
- PostgreSQL Replication之第十二章 与Postgres-XC一起工作(7)
12.7 处理故障转移和删除节点 在本节中,我们将看看故障切换如何处理.我们还将看看如何使用安全可靠的方法添加节点到Postgres-XC设置以及如何从Postgres-XC设置删除节点. 12.7. ...
- Leetcode: Guess Number Higher or Lower
We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You have to gues ...
- 代码实现sql数据库的附加(通常在安装的时候)
判断数据库是否已经存在 SqlConnection judgeConn = new SqlConnection("server=.;database=master;uid="+us ...
- android 单例模式
单例模式特点: 1.一个类只能有一个实例 2.自己创建这个实例 3.整个系统都要使用这个实例 单例模式的形式: 1.饿汉式单例类 public class Singleton { private Si ...
- run()和star()区别
run()和star()区别 run()-->只是thread类的一个普通方法调用 star()-->用来启动线程,实现多线程运行
- web server与app server有什么不同
简单来说,web服务器提供页面给浏览器,而app服务器提供客户端可以调用的接口.具体而言,我们可以说: Web服务器处理HTTP请求,而app服务器基于多种不同的协议,处理应用程序的逻辑问题. 以下将 ...
- paper 2:图像处理常用的Matlab函数汇总
一 图像的读写 1 imread imread函数用于读入各种图像文件,如:a=imread('e:\w01.tif') 注:计算机E盘上要有w01相应的.tif文件. 2 imwrite imwri ...
- rails控制台进入
数据库控制台: rails db .help查看可使用的命令 rails控制台 rails c 普通ruby控制台: irb
- DDR3命令状态(二)
DDR3中的状态机Diagram,详见相册. ACT:Activate,表示输出行地址,和是否自动precharge控制位. PRE:Precharge,在读写后,可以根据A10来判断是否自己进行pr ...