`
jiao13953900900
  • 浏览: 32219 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

黑马程序员-集合1-List集合

    博客分类:
  • java
阅读更多

 

---------------------- android培训java培训、期待与您交流! ----------------------

 

 

集合1-List集合

 

 

 

集合框架 Collection

在java.util包中

Collection

|--List(列表):元素是有序的,元素可以重复。因为该集合体系有索引。

|--ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快。但是增删稍慢。线程不同步。可变数组长度延长50%

|--LinkedList:底层使用的链表数据结构。特点:增删速度很快,查询稍慢。线程不同步。

|--Vector:底层是数组数据结构。线程同步。被ArrayList替代了。因为效率低。可变数组长度100%延长,

一般开发中在要求线程同步的时候对ArrayList加锁也不使用Vector。

|--Set(集):元素是无序,元素不可以重复。

 

问什么会出现那么多的集合容器呢。

因为每一个容器对数据的存储方式都有不同,这个存储方式称为:数据结构。

 

集合类

 

1.为什么出现集合类?

面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式。

 

2.数组和集合类同是容器,有何不同?

数组虽然也可以存储对象,但长度是固定的;集合长度是可变的。数组中可以存储基本数据类型,集合只能存储对象。

 

3.集合类的特点:

1.集合只用于存储对象,

2.集合长度是可变的,

3.集合可以存储不同类型的对象。

集合中存储的都是对象的引用(地址)

 

 

Collection定义了集合框架的共性功能。

1,添加

add(e);,add方法的参数类型是Object。以便于接收任意类型对象。

addAll(collection); //在集合中添加一个集合中的元素。

 

2,删除

remove(e);删除一个 任意类型的元素,返回boolean类型的值。

removeAll(collection); 移除此 collection 中那些也包含在指定 collection 中的所有元素

clear(); 移除此 collection 中的所有元素,即清空集合。

 

3,判断。

contains(e);如果此 collection 包含指定的元素,则返回 true。

isEmpty(); 判断集合是否为空,空则返回true

 

4,获取

iterator(); 获取一个迭代器对象。

size(); 获取集合的长度。

 

5,获取交集。

retainAll();仅保留此 collection 中那些也包含在指定 collection 的元素

 

6.获取并集。

removeAll();移除此 collection 中那些也包含在指定 collection 中的所有元素

 

7,集合变数组。

  Object[] toArray();返回包含此 collection 中所有元素的数组

<T> T[]  toArray(T[] a) 返回包含此 collection 中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。

 

 

什么是迭代器呢?

其实就是集合的取出元素的方式。

 

迭代器是取出方式,会直接访问集合中的元素。

所以将迭代器通过内部类的形式来进行描述。

通过容器的iterator()方法获取该内部类的对象。

 

迭代器设计方式:

对于集合中元素的取出,不只一共动作,用一个函数不足以来描述,所以将取出的方式封装到一个对象中,并且,因为数据结构不同,每一个数据的取出方式也都不一样。。所以,取出方式需要被描述一下,就定义了一个类进行描述,因为取出方式是集合提供的,所以描述取出方式的类定义在集合内部,这样取出方式就可以直接访问集合内部的元素。那么取出方式就定义为了内部类,而每一个容器的数据结构不一样,所以抽取的动作细节也不一样,但是都有共性的内容,判断和取出,那么,将这些共性内容进行抽取,封装到内部类中。

 

 

下面是collection接口中的方法示例:

class  CollectionDemo
{
	public static void main(String[] args) 
	{
		
		base_method();
	}
	public static void base_method()
	{
		//创建一个集合容器。使用Collection接口的子类。ArrayList
		ArrayList al = new ArrayList();

		//1,添加元素。
		al.add("java01");//add(Object obj);
		al.add("java02");
		al.add("java03");
		al.add("java04");

		ArrayList al2 = new ArrayList();

		al2.add("java03");
		al2.add("java04");
		al2.add("java05");
		al2.add("java06");

		//打印原集合。
		sop("原集合:"+al);


		//3,删除元素。
		//al.remove("java02");
		//al.clear();//清空集合。


		//4,判断元素。
		sop("java03是否存在:"+al.contains("java03"));
		sop("集合是否为空?"+al.isEmpty());


		//2,获取个数。集合长度。
		sop("size:"+al.size());

		//打印改变后的集合。
		sop(al);

		//al.retainAll(al2);//获取al和al2的交集存入到al中,al1中只会保留和al2中相同的元素。
		//al.removeAll(al2);//删除al中与al2相同部分的元素,即取并集。

		sop("al1:"+al);
		sop("al2:"+al2);

		//对集合中的元素进行遍历。
		for(Iterator it = al.iterator(); it.hasNext() ; )
		{
			sop(it.next());
		}

	}

	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
}

 

 

 

List:

特有方法。凡是可以操作角标的方法都是该体系特有的方法。

 

add(index,element);

addAll(index,Collection);

 

remove(index);

 

set(index,element);

get(index):

subList(from,to);

listIterator();

int indexOf(obj):获取指定元素的位置。

ListIterator listIterator();

 

 

注意:List集合的contains和remove方法底层全部调用equals方法进行比较。

 

 

List集合特有的迭代器。ListIterator是Iterator的子接口。

 

在迭代时,不可以通过集合对象的方法操作集合中的元素。

因为会发生ConcurrentModificationException异常。

 

所以,在迭代器时,只能用迭代器的放过操作元素,可是Iterator方法是有限的,

只能对元素进行判断,取出,删除的操作,

如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。

 

该接口只能通过List集合的listIterator方法获取。

import java.util.*;
class ListDemo 
{
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
	public static void method()
	{
		
		ArrayList al = new ArrayList();

		//添加元素
		al.add("java01");
		al.add("java02");
		al.add("java03");
		
		sop("原集合是:"+al);
		//在指定位置添加元素。
		al.add(1,"java09");

		//删除指定位置的元素。
		//al.remove(2);

		//修改元素。
		//al.set(2,"java007");

		//通过角标获取元素。
		sop("get(1):"+al.get(1));

		sop(al);

		//获取所有元素。
		for(int x=0; x<al.size(); x++)
		{
			System.out.println("al("+x+")="+al.get(x));
		}

		Iterator it = al.iterator();

		while(it.hasNext())
		{
			sop("next:"+it.next());
		}


		//通过indexOf获取对象的位置。
		sop("index="+al.indexOf("java02"));

		List sub = al.subList(1,3);

		sop("sub="+sub);
	}

	
	public static void main(String[] args) 
	{

		//演示列表迭代器。
		ArrayList al = new ArrayList();

		//添加元素
		al.add("java01");
		al.add("java02");
		al.add("java03");

		sop(al);

		
		ListIterator li = al.listIterator();

		
		//sop("hasPrevious():"+li.hasPrevious());

		while(li.hasNext())
		{
			Object obj = li.next();//得到下一个元素

			if(obj.equals("java02"))//对得到的元素进行判断
				//li.add("java009");//在得到的元素后面添加新元素
				li.set("java006");//对得到的元素进行设置。


		}

		while(li.hasPrevious())
		{
			sop("pre::"+li.previous());//获取前一个元素。
		}
		//sop("hasNext():"+li.hasNext());
		//sop("hasPrevious():"+li.hasPrevious());判断有没有前一个元素


		sop(al);



		/*普通的迭代器只能实现删除的操作,并且在迭代过程中无法使用集合的增删方法。
		//在迭代过程中,准备添加或者删除元素。

		Iterator it = al.iterator();

		while(it.hasNext())
		{
			Object obj = it.next();

			if(obj.equals("java02"))
				//al.add("java008");
				it.remove();//将java02的引用从集合中删除了。

			sop("obj="+obj);
		}
		sop(al);
		*/
		


	}
}

 

 

枚举就是Vector特有的取出方式。

发现枚举和迭代器很像。

其实枚举和迭代是一样的。

 

因为枚举的名称以及方法的名称都过长。

所以被迭代器取代了。

枚举郁郁而终了。

 

使用枚举对vector中的元素进行遍历。

class VectorDemo 
{
	public static void main(String[] args) 
	{
		Vector v = new Vector();

		v.add("java01");
		v.add("java02");
		v.add("java03");
		v.add("java04");

		Enumeration en = v.elements();//获取枚举

		while(en.hasMoreElements())//判断有没有下一个元素
		{
			System.out.println(en.nextElement());//获取下一个元素
		}
	}
}

 

 

 

 LinkedList:特有方法:

addFirst(); 从最前面添加

addLast(); 从最后面添加

 

getFirst(); 从最前面获取

getLast(); 从最后面获取

获取元素,但不删除元素。

如果集合中没有元素,会出现NoSuchElementException

 

removeFirst(); 从最前面删除

removeLast(); 从最后面删除

获取元素,但是元素被删除。

如果集合中没有元素,会出现NoSuchElementException

 

在JDK1.6出现了替代方法。

offerFirst(); 替代了addFirst添加

offerLast();

 

peekFirst(); 替代了获取

peekLast();

获取元素,但不删除元素。如果集合中没有元素,会返回null。

 

pollFirst(); 替代了原有的删除

pollLast();

获取元素,但是元素被删除。如果集合中没有元素,会返回null。

 


class LinkedListDemo 
{
	public static void main(String[] args) 
	{
		LinkedList link = new LinkedList();

		link.addLast("java01");
		link.addLast("java02");
		link.addLast("java03");
		link.addLast("java04");

		sop(link);
		sop(link.getFirst());
		sop(link.getFirst());
		sop(link.getLast());
		sop(link.removeFirst());
		sop(link.removeFirst());

		sop("size="+link.size());

		while(!link.isEmpty())
		{
			sop(link.removeLast());
		}

	}

	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
}

 

 

在开发中怎么选择这些容器呢:

如果在开发中需要频繁的增删操作,使用LinkedList,

涉及到增删也涉及到查询,建议使用arrayList

 

 

 

---------------------- android培训java培训、期待与您交流! ----------------------

分享到:
评论

相关推荐

    黑马程序员-Java语言进阶-源码、教程笔记.zip

    day03_List、Set、数据结构、Collections day04_Map,斗地主案例 day05_异常,线程 day06_线程、同步 day07_等待与唤醒案例、线程池、Lambda表达式 day08_File类、递归 day09_字节流、字符流 day10_缓冲流、转换流、...

    HeiMaJavaWebVideo:黑马程序员-超全面的JavaWeb教程-原始笔记

    黑马程序员-超全面的JavaWeb教程-原始笔记 HeiMaJavaWebVideo 黑马程序员-超全面的JavaWeb教程继承笔记 Day01 01. README.txt ===&gt;课堂笔记02. Contents.txt ===&gt;课堂目录03. Hello.html ===&gt;演示字体标签和HTML的...

    黑马程序员

    java的 private static void addSex() throws Exception{ DocumentBuilderFactory buiderFactory = DocumentBuilderFactory.new... NodeList list = document.getElementsByTagName("p1"); Node p1 = list.item(0);

    黑马程序员基础测试题答案

    9、 定义一个静态方法,该方法可以接收一个List,方法内对List进行排序 10、 声明类Student,包含3个成员变量:name、age、score,创建5个对象装入TreeSet,按照成绩排序输出结果(考虑成绩相同的问题)。

    【IT十八掌徐培成】Java基础第10天-03.List-集合框架-ArrayList.zip

    【IT十八掌徐培成】Java基础第10天-03.List-集合框架-ArrayList.zip

    Java-Java集合体系-List-Set

    Java-Java集合体系-List-Set 内容概要:总结了Java集体体系中的三大集合接口LIst、Set、Map,本文对LIst、Set做出了详细、简要的分析,没有冗长的文章,全是干货,下载即用,其中涉及了其底层实现,面试题必备。 ...

    _Java-集合容器-2.List及其实现类.ppt

    _Java-集合容器-2.List及其实现类.ppt

    react-virtual-list:超简单的虚拟化列表React组件

    遗产如果您正在寻找支持~0.13.x版本1的文档,请~0.13.x。安装您可以使用安装 。 &gt; npm install react-virtual-list --save用法./lib/VirtualList.js模块导出单个ES5兼容的,可访问CommonJS的组件工厂。 import ...

    集合相关--------集合相关.pdf

    Java集合,Map,Set,List,相关对比和比较等概念,自己总结,希望能帮助到大家, Java集合,Map,Set,List,相关对比和比较等概念,自己总结,希望能帮助到大家

    超市会员管理系统.rar

    所有会员(卡)--集合:List ArrayList&lt;Member&gt; 程序整体流程搭建的方法 循环 分支 验证会员是否存在的方法 集合的遍历,集合元素的查找 系统随机生成会员卡号的方法 Random类 开卡 输入会员信息...

    JavaSE专题-List集合.doc

    1、集合是Java API所提供的一系列类,可以用于动态存放多个对象。--集合只能存对象 2、集合与数组的不同在于,集合是大小可变的序列,而且元素类型可以不受限定,只要是引用类型。(集合中不能放基本数据类型,但可以...

    思科路由器access-list命令集合

    思科路由器的access-list命令用法集合

    tesseract --list-langs 中文

    tesseract --list-langs 中文

    List集合排序222222

    List sortList = controllerForList.sortList(list, arr1, arr2); 参数1 排序的集合 参数2 排序的字段(与定义字段一致) 可多个 参数3 排序方式(asc desc) 暂时只支持String 和int的排序 可能有些BUG 敬请谅解

    JSP应用开发-Java集合类-List接口.pptx

    JSP应用开发-Java集合类-List接口.pptx

    13-IoC配置-集合注入

    使用集合方式注入Ioc ... //list集合 private List&lt;Integer&gt; lists; //map集合 private Map,Object&gt; maps; //set集合 private Set&lt;String&gt; sets; //properties private Properties properties;

    帝国带时间标签模板的list-var1变量代码

    帝国带时间标签模板的list-var1变量代码添加后标签后在网页中格式为左标题 右时间

    JSON--List集合转换成JSON对象详解

    主要介绍了List集合转换成JSON对象,小编觉得挺不错的,现在就分享给大家,也给大家做个参考。

    publicsuffix-list-dafsa-20180723-1.el8.noarch.rpm

    官方离线安装包,亲测可用。使用rpm -ivh [rpm完整包名] 进行安装

    Java高级程序设计:第7章-集合框架.pptx

    (1) 集合(Set) — 无重复对象 (2) 列表(List) — 允许重复对象,按索引检索,类似 数组 (3) 映射(Map) — 每个元素由key对象和value对象组成, key不重复 Collection Framework Collection Framework java.util....

Global site tag (gtag.js) - Google Analytics