疯狂Java学习笔记(34)----------Iterator、Collection接口以及foreach
疯狂Java学习笔记(34)----------Iterator、Collection接口以及foreach
Iterator、Collection接口:
如下图:Iterator、Collection同在一个包中:
红字部分使我们经常遇到的,但是遇到又不知道怎么去理解,去应用它!
Collection是最基本集合接口,它定义了一组允许重复的对象。Collection接口派生了两个子接口Set和List,分别定义了两种不同的存储方式,如下:
2、 Set接口
Set接口继承于Collection接口,它没有提供额外的方法,但实现了Set接口的集合类中的元素是无序且不可重复。
特征:无序且不可重复。
3、 List接口
List接口同样也继承于Collection接口,但是与Set接口恰恰相反,List接口的集合类中的元素是对象有序且可重复。
特征:有序且可重复。
两个重要的实现类:ArrayList和LinkedList
1.ArrayList特点是有序可重复的
2.LinkedList是一个双向链表结构的。
4、Map接口
Map也是接口,但没有继承Collection接口。该接口描述了从不重复的键到值的映射。Map接口用于维护键/值对(key/value pairs)。
5.Iterator接口
Iterator接口,在C#里有例外一种说法IEnumerator,他们都是集合访问器,用于循环访问集合中的对象。
所有实现了Collection接口的容器类都有iterator方法,用于返回一个实现了Iterator接口的对象。Iterator对象称作迭代器,Iterator接口方法能以迭代方式逐个访问集合中各个元素,并可以从Collection中除去适当的元素。
下面将是展现真正的实力了!
CollectionTest.java代码
- package com.haixu.collection;
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.HashSet;
- /**
- * Collection集合内部方法的学习!
- * */
- public class CollectionTest {
- public static void main(String[] args) {
- Collection<String> c =new ArrayList<String>();
- //向集合内添加元素
- c.add("Hi!");
- c.add("Haixu");
- //输出各个元素
- System.out.println("c的集合元素个数:"+c.size());
- //虽然集合里不能放基本类型的值,但Java支持自动装箱!
- //删除指定的元素
- c.remove(2);
- System.out.println("c的集合元素个数:"+c.size());
- //判断集合c中是否包含字符串"Haixu"
- System.out.println("c的集合中是否有\"Haixu\"字符串:" + c.contains("Haixu"));
- //继续向集合内添加元素并将集合元素输出出来
- c.add("You are very perfect!");
- System.out.println("c的集合中的元素为:" + c);
- //用HsahSet定义对象c1
- Collection<String> c1 = new HashSet<String>();
- //添加元素
- c1.add("Believe yourself!");
- c1.add("Haixu!");
- c1.add("you will success!");
- System.out.println(c1);
- //判断c集合是否完全包含c1集合
- System.out.println("c集合是否完全包含c1集合?" + c.contains(c1));
- c.removeAll(c1);
- System.out.println("c的集合元素为:" + c);
- //清空集合c
- c.clear();
- System.out.println("c的集合元素为:" + c);
- c1.retainAll(c);
- System.out.println("c1的集合元素为:" + c1);
- }
- }
IteratorTest.java
- package com.haixu.collection;
- import java.util.Collection;
- import java.util.HashSet;
- import java.util.Iterator;
- /*
- * Iterator 用于遍历集合
- * */
- public class IteratorTest {
- public static void main(String[] args) {
- Collection<String> str1 = new HashSet<String>();
- //添加元素
- str1.add("Everything that you can do!");
- str1.add("if only you hard work continuely!");
- str1.add("Success will belong to you!");
- //获取str1集合对应的迭代器
- Iterator<String> it = str1.iterator();
- while(it.hasNext()){
- String str = (String)it.next();
- System.out.println(str);
- if(str.equals("Everything that you can do!"));
- it.remove();
- str = "Everything that you can do!";
- System.out.println(str);
- }
- System.out.println(str1);
- }
- }
foreach循环来迭代访问Collection集合里的元素跟家简洁一点!
foreach循环迭代方位集合元素是,该集合不可改变否则将会引发ConcurrentModificationException异常!
ForeEachTest.java
- package com.haixu.collection;
- import java.util.Collection;
- import java.util.HashSet;
- /*
- * foreeach 循环来迭代Collection集合里的元素
- * */
- public class ForeEachTest {
- public static void main(String[] args) {
- Collection<String> str1 = new HashSet<String>();
- //添加元素
- str1.add("Everything that you can do!");
- str1.add("if only you hard work continuely!");
- str1.add("Success will belong to you!");
- for(Object obj : str1){
- String str = (String) obj;
- System.out.println(str);
- if(str.equals("Everything that you can do!")){
- //下面的代码会引发异常
- //是故意的!
- str1.remove(str);
- }
- }
- System.out.println(str1);
- }
- }
以上就是各个接口的应用和使用情况。
因为其中有一个返回值为Iterator<E>类型的iterator()方法,所以,Collection接口必须实现Iterator接口
实现Collection接口的每一个类都要实现以上众多方法,但开发者自己实现很麻烦。所以java提供了AbstractCollection类来编写具体的类。
以下类都实现了Collection接口:
AbstractCollection, AbstractList, AbstractQueue, AbstractSequentialList, AbstractSet, ArrayBlockingQueue, ArrayDeque, ArrayList, AttributeList, BeanContextServicesSupport, BeanContextSupport, ConcurrentLinkedDeque,ConcurrentLinkedQueue, ConcurrentSkipListSet, CopyOnWriteArrayList, CopyOnWriteArraySet, DelayQueue, EnumSet, HashSet, JobStateReasons, LinkedBlockingDeque, LinkedBlockingQueue, LinkedHashSet, LinkedList,LinkedTransferQueue, PriorityBlockingQueue, PriorityQueue, RoleList, RoleUnresolvedList, Stack, SynchronousQueue, TreeSet, Vector
转载自:https://blog.csdn.net/u011225629/article/details/45826631
文章来源: brucelong.blog.csdn.net,作者:Bruce小鬼,版权归原作者所有,如需转载,请联系作者。
原文链接:brucelong.blog.csdn.net/article/details/79992905
- 点赞
- 收藏
- 关注作者
评论(0)