JAVA学习第三十四课 (经常使用对象API)—List集合及其子类特点

整个集合框架中最经常使用的就是List(列表)和Set(集)

一、List集合 && Set的特点

Collection的子接口:

1、List:有序(存入和取出的顺序一致),元素都有索引且能够反复

   API文档解释:有序的 collection(也称为序列)。此接口的用户能够对列表中每一个元素的插入位置进行精确地控制。用户能够依据元素的整数索引(在列表中的位置)訪问元素,并搜索列表中的元素。

2、Set:元素不能反复,无序,有可能会有序

   API文档解释:一个不包括反复元素的 collection。更确切地讲,set 不包括满足e1.equals(e2)
的元素对 e1e2,而且最多包括一个 null 元素。正如其名称所暗示的,此接口模仿了数学上的set 抽象。

....

依据问题须要使用相应的容器

二、List常见方法

由于是Collection的子类,仅仅演示其特有方法

1.加入
	void add(index,element)
	void add(index,Collection)
2.删除
	Object remove(index)
3.改动
	Object set(index,element)
4.获取
	Object get(index)
	int indexOf(Object)
	int lastIndexOf(Object)
	List subList(from,to)//含头,不含尾

代码演示

import java.util.ArrayList;
import java.util.List;

public class Main
{
	public static void main(String[] args)
	{
		List list = new ArrayList();//注意LIst的包不要导入错误,java.awt中也有个List
		show(list);
	}
	public static void show(List list)
	{
		//加入
		list.add("a1");
		list.add("a2");
		list.add("a3");
		System.out.println("List = "+list);

		//加入元素
		//list.add(2,"a250");

		//删除元素
		//list.remove(2);

		//改动(Collection不具备改动)
		//list.set(2, "a25");

		//获取
		//list.get(1);
		//System.out.println("list = "+list.get(1));

		//获取子列表
		List LL = list.subList(0, 2);//含头,不含尾
		System.out.println("ZI List = "+LL);

	}
}

由上可见,List的特有的常见方法有一个共性就是都能够操作角标->增删改查

三、ListIterator接口:List特有

   API文档解释:系列表迭代器,同意程序猿按任一方向遍历列表、迭代期间改动列表,并获得迭代器在列表中的当前位置。

ListIterator迭代器,是为了处理迭代器迭代和集合操作出现并发改动时,出现的异常问题

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;

public class Main
{
	public static void main(String[] args)
	{
		List list = new ArrayList();
		//show(list);
		ListIteratorDemo(list);
	}
	public static void ListIteratorDemo(List list)
	{
		list.add("a1");
		list.add("a2");
		list.add("a3");

		//Iterator it = list.iterator();//此时的it仅仅知道当前状态的list的内部数据结构的存储方式
		//所下面述代码会抛出异常,由于后来list结构变化了,it不知道
		/*while(it.hasNext()) {
			Object object = it.next();
			if (object.equals("a2")) {
				list.add("a250");//ConcurrentModificationException
				//此异常的原因是:当方法检測到对象的并发改动,但不同意这样的改动时,抛出此异常。
			}
			else {
				System.out.println(object);
			}
		}*/

		//解决:迭代和集合同一时候訪问造成了并发,所以集合操作的时候不迭代,迭代的时候不使用集合操作
		System.out.println("Old List :"+list);
		ListIterator iterator = list.listIterator();
		//list特有迭代器,能够实如今迭代过程中完毕对元素的增删改查
		/*listIterator(int index)
          返回列表中元素的列表迭代器(按适当顺序),从列表的指定位置開始。*/
		while (iterator.hasNext()) {
			Object object = iterator.next();
			if(object.equals("a2")){
				iterator.add("a250");//注意此处就不用list,而是使用的迭代器,避免并发
			}
		}
		System.out.println("New List:"+list);
		//System.out.println("hasNext? "+iterator.hasNext());
		//System.out.println("hasPrevious? "+iterator.hasPrevious());
		while(iterator.hasPrevious())
		{
			System.out.println(iterator.previous());
		}
	}
}

四、List经常使用子类特点

1.Vector:内部是数组结构,且同步,增删慢,查询慢

    API文档解释:Vector 类能够实现可增长的对象数组。与数组一样,它包括能够使用整数索引进行訪问的组件。可是,Vector 的大小能够依据须要增大或缩小,以适应创建Vector 后进行加入或移除项的操作。

2.ArrayList:内部是数组结构,不同步替代了Vector,查询速度快

   API文档解释:List 接口的大小可变数组的实现。实现了全部可选列表操作,并同意包含null 在内的全部元素。除了实现List
接口外,此类还提供一些方法来操作内部用来存储列表的数组的大小。(此类大致上等同于Vector 类,除了此类是不同步的。)

3.LinkedList:内部是链式存储结构,不同步,增删速度快

   API文档解释:List 接口的链接列表实现。实现全部可选的列表操作,而且同意全部元素(包含null)。除了实现List 接口外,LinkedList
类还为在列表的开头及结尾 getremoveinsert 元素提供了统一的命名方法。这些操作同意将链接列表用作堆栈、队列或双端队列。

时间: 2024-08-09 06:48:01

JAVA学习第三十四课 (经常使用对象API)—List集合及其子类特点的相关文章

JAVA学习第三十四课(常用对象API)- 集合框架(二)—List集合及其子类特点

整个集合框架中最常用的就是List(列表)和Set(集) 一.List集合 && Set的特点 Collection的子接口: 1.List:有序(存入和取出的顺序一致),元素都有索引且可以重复    API文档解释:有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素. 2.Set:元素不能重复,无序,有可能会有序    API文档解释:一个不包含重复元素的 coll

JAVA学习第三十六课(常用对象API)- 集合框架(四)— Set集合:HashSet集合演示

随着Java学习的深入,感觉大一时搞了一年的ACM,简直是明智之举,Java里很多数据结构.算法类的东西,理解起来就轻松多了 Set集合下有两大子类开发常用 HashSet集合 .TreeSet集合 Set集合的元素是不重复且无序 一.HashSet集合 API文档解释:此类实现 Set 接口,由哈希表(实际上是一个 HashMap 实例)支持.它不保证 set 的迭代顺序:特别是它不保证该顺序恒久不变.此类允许使用null 元素. 此类为基本操作提供了稳定性能,注意,此实现不是同步的. 由上可

JAVA学习第三十九课(常用对象API)- 集合框架(七)— Map集合及其子类对象

一.Map集合常见子类 HashTable:内部结构是哈希表,同步,此实现提供所有可选的映射操作,不允许使用 null 值和 null 键 (HashTable下有子类Properties,使用频率非常高,用来存储键值对型的配置文件信息和IO技术相结合) HashMap:内部结构是哈希表,不同步,此实现提供所有可选的映射操作,并允许使用 null 值和 null 键. TreeMap:内部结构是二叉树,不同步,可以对Map集合中的键进行排序. 二.HashMap演示 import java.ut

JAVA学习第五十四课 — IO流(八)打印流 & 序列流

一.综合练习-文件清单列表 获取指定目录下,指定扩展名的文件(含子目录),并将这些文件的绝对路径写到一个文本文件中.也就是建立一个指定扩展名的文件列表 1.深度遍历 2.过滤器->容器 3.写入文件 import java.util.List; import java.io.*; import java.util.ArrayList; public class Main { public static void main(String[] args) throws IOException { F

JAVA学习第六十四课 — 反射机制

   Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法,对于任意一个对象,都能够调用它的任意一个方法和属性,这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制,简单说:能动态获取类中的信息(类中所有),就是java的反射,也可以理解为对类的解剖 反射机制的基本应用场景:    比如一个程序的应用程序(TomCat),为了提高其扩展性,会对外暴露一个接口,在外部定义一个类实现这个接口,但是在应用程序内部无法new对象,所以应用程序会提供一个配置

JAVA学习第三十二课(常用对象API)- 基本数据类型对象包装类

将基本数据类型(8种:int..)封装成对象的好处就是可以在对象中封装更多的功能和方法来操控该数据 常见的操作就是:用于基本数据类型与字符串之间的转换 基本数据类型对象包装类一般用于基本类型和字符串之间的转换 基本类型----->字符串 1.基本类型数值+"" 2.用string类中的valueOf(基本类型数值) 3.用Integer.ValueOf(); 字符串-->基本类型数值 1.使用包装类中的静态方法XXX  parseXXX("XXXX")比

JAVA学习第三十八课(常用对象API)- 集合框架(六)— Map集合及其常用方法

一.Map集合特点 Map集合(双列集合)一次添加一对元素,Collection集合(单列集合)一次添加一个元素 接口 Map<K,V>,实际上存储的是键值对 特点: 将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 也就是说Map中必须保证键的唯一性 二.常用方法 1.添加:value = put(key,value);返回前一个和key相关联的值,如果没有返回null 2.删除:void clear();把Map中的所有映射关系清除 value remove(ke

JAVA学习第三十五课(常用对象API)- 集合框架(三)—Vector、LinkedList、ArrayList集合演示

集合框架构成图 摘自百度图片 一.Vector集合 演示 虽然Vector已经不常用了,但是还是要了解一下其中的方法 import java.util.ArrayList; import java.util.Enumeration; import java.util.Iterator; import java.util.LinkedList; import java.util.List; import java.util.ListIterator; import java.util.Vector

JAVA学习笔记(三十四)- 字节打印流 PrintStream

PrintStream字节打印流 import java.io.BufferedReader; import java.io.FileOutputStream; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.PrintStream; import java.io.PrintWriter; import java.io.Reader; /* * Pri