---------------------- 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培训、期待与您交流! ----------------------