●一方面,面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就要对对象进行存储。另一方面,使用Array存储对象方面具有一些弊端,而Java集合就像一种容器,可以动态地把多个对象的引用放入容器中。
说明:此时的存储,主要指的是内存层面的存储,不涉及到持久化的存储
≥数组在内存存储方面的特点: √数组初始化以后,长度就确定了。 √数组声明的类型,就决定了进行元素初始化时的类型,String[] arr,int[] arr,
≥数组在存储数据方面的弊端: √数组初始化以后,长度就不可变了,不便于扩展 √数组中提供的属性和方法少,不便于进行添加、删除、插入等操作,且效率不 高。同时无法直接获取存储元素的个数 √数组存储的数据是有序的、可以重复的,对于无序、不可重复的需求,不能满 足。
---->存储数据的特点单一 Java集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组。
Java集合可分为 Collection和 Map 集合
≥Collection接口:单列数据,定义了存取一个一个的对象
√List接口: 元素有序、可重复的集合。 --> "动态"数组
--->子接口的具体实现类 ArrayList 、LinkedList 、Vector
√Set接口: 元素无序、不可重复的集合
---->HashSet 、LinkHashSet 、TheeSet
≥Map 接口:双列数据,保存具有映射关系“(key - value)”一对的数据 -->函数 y= f(x)
---->HashMap 、LinkHashMap 、TressMap 、 Hashtable 、Properties
向Collection接口的实现类的对象中添加数据obj时,要求obj所在类要重写equals()
使用迭代器Iterator接口
Iterator对象称为迭代器(设计模式的一种),主要用于遍历Collection集合中的元素。
GOF给迭代器模式的定义为:提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节。迭代器模式,就是为容器而生。类似于“公交车上的售票员”、“火车上的乘务员”、“空姐”。 ? Collection接口继承了java.lang.lterable接口,该接口有一个iterator()方法,那么所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了lterator接口的对象。 ? lterator仅用于遍历集合,lterator木身并不提供承装对象的能力。如果需要创建lterator对象,则必须有一个被迭代的集合。 ? 集合对象每次调用iterator()方法都得到一个全新的迭代器对象**,默认游标都在集合的第一个元素之前。
内部的方法:hasNext():判断是否还有下一个元素
next():指针下移 将下移位置上的元素返回
如果还未调用next()或在上一次调用next方法之后已经调用了 remove方法,在调用remove都会报异常
@Test
public void test(){
Collection coll = new ArrayList();
coll.add(123);
coll.add(456);
coll.add(new String("Tom"));
coll.add(false);
coll.add(new Person("jerry", 20));
?
//for(集合元素的类型 局部变量 : 集合对象)
//内部仍然调用了迭代器
for(Object obj:coll){
System.out.println(obj);
}
}
?
@Test
public void test2(){
int[] arr = new int[]{1,2,3,4,5};
//for(数组元素的类型 局部变量 : 数组对象)
for(int i : arr){
System.out.println(i);
}
}
原文:https://www.cnblogs.com/flypigggg/p/14613979.html