集合的由来:
我们学习的是面向对象的语言,而面向对象的语言对事物的描述是通过对象体现的,为了方便多个对象进行操作,我们就必须把这个对象进行存储.而要想存储多个对象,就不能是一个基本的变量,而应该是一个容器类型的变量,在我们目前所学的知识里面,数组和StringBuffer是容器类型的.但是StringBuffer的结果是一个字符串,不一定满足我们的需求,所以我们只能选择数组,这就是对象数组.而对象数组不能适应变化的需求,因为数组的长度是固定的,这个时候.为了适应变化的需求,Java就提供了集合供我们使用.
数组和集合的区别:
A:长度区别
数组的长度固定.
集合的长度可变.
B:内容不同
数组储存的是同一种类型的元素.
而集合可以存储不同类型的元素.
C:元素的数组类型问题
数组可以存储基本数据类型,也可以存储引用数据类型.
集合只能存储引用类型,不能存储基本类型.
Collection:
介绍:
集合是存储多个元素的,但是存储多个元素我们也有不同的需求:例如不能有相同元素,或者按一定顺序排序等.
针对不同的需求,Java就提供了不同的集合类,这样Java就提供了很多个集合类.这多个集合类的数据结构不同,但是多个集合类的功能是有共性的,所以就不断的提取相同功能,我们就得到一个集合的继承体系,
这个体系的老大是Collection,两个子派别List和Set.
功能概述:
Collection是集合的顶层接口,它的子体系有重复的,有唯一的,有有序的,有无序的.
添加:
boolean add(E e);添加一个元素.
boolean addAll(Collection c);添加一个集合元素
删除:
void clear();移除所有元素
boolean remove(Object o);移除一个元素.
boolean removeAll(collection c);移除一个集合里面有的元素.
判断:
boolean contains(object o);判断集合中是否包含指定元素
boolean containsAll(collection c);判断集合中是否包含结合元素,必须包含集合中的所有元素才true.
boolean isEmpty();判断元素是否为空,有元素就true,没元素就false.
获取:
Iterator<E> iterator;
获取长度:
int size();元素的个数
交集功能:
boolean retainAll(collection c);两个集合都有元素.
注意:
假设有两个集合A,B.
A对B做交集,最终的结果保存在A中,B不变.
返回值表示A是否发生改变.而不是是否有交集.
把集合转为数组:
Object[] toArray();
迭代器,集合专用遍历方式:
Iterator iterator();构造方法.集合专用遍历方式.返回的是子类对象.
注意点:
1.如果是用循环遍历,可以用for循环,改进while循环遍历.
2.如果用迭代器遍历,主要不要多次使用next();方法,可能会发生数据错乱.
迭代器是遍历集合的一种方式,迭代器是依赖于集合而存在的.
迭代器的使用步骤:
A:创建集合对象.
B:创建元素对象.
C:把元素对象添加到集合中.
D:遍历集合:
a:通过集合对象,获取迭代对象.
b:通过迭代器的hasNext()方法判断是否有元素
c:通过迭代器的next();方法获取元素并且移动到下一位置.
网友评论