JAVA中集合基本操作

原文出自:http://www.cnblogs.com/CocoonFan/archive/2013/03/11/2953312.html


在编程的时候,常常需要集中存放多个数据。我们可以使用数组来存放这些数据,但是数组有一个缺点:数组的长度是不可变的,数组的空间开辟太大会造成浪费,开辟的空间太小又不够用。这时候就可以使用集合了。

  为了保存数量不确定的数据和保存具有映射关系的数据,Java提供了集合类。所有的集合类都在 java.util包下。

  Java的集合类主要由两个接口派生出:Collection和Map.这两个接口又包含了一些子接口或者实现类。

下图是java 集合体系

  在Set和List接口是Collection派生出来的两个子接口,分别代表了无序集有序集
  Map保存的每项数据都是key-value对,其中key是不可重复的,需要查阅Map中的值时总是根据key来获取

 

下面列出了Collection定义的操作集合元素的方法:
  · boolean add(Object):确保容器能持有你传给它的那个参数。如果没有把它加进去,就返回false。
  · boolean addAll(Collection):加入参数Collection所含的所有元素。只要加了元素,就返回true。
  · void clear():清除容器所保存的所有元素。
  · boolean contains(Object):如果容器持有参数Object。
  · boolean containsAll(Collection):判断一个集合是否是另一个集合的子集。
  · boolean isEmpty():如果容器里面没有保存任何元素,就返回true。
  · Iterator iterator():返回一个可以在容器的各元素之间移动的Iterator。
  · boolean removeAll(Collection):集合的差。只要删过东西,就返回true。
  · boolean retainAll(Collection):只保存参数Collection所包括的元素(集合论中“交集”的概念)。如果发生过变化,则返回true。
  · int size():返回容器所含元素的数量。
  · Object[] toArray():返回一个包含容器中所有元素的数组。
  · Object[] toArray(Object[] a):返回一个包含容器中所有元素的数组,且这个数组不是普通的Object数组,它的类型应该同参数数组a的类型相同(要做类型转换)。

下面这个例子演示了常用的集合操作:

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;


public class IteratorTest {
    public static void main(String[] args) {
        Collection collection = new ArrayList();
        
        //添加元素
        //虽然Java集合不能放基本类型的值,但Java 1.5之后增加了自动装箱拆功能
        collection.add(100);
        collection.add(new Boolean(false));
        collection.add("Cocoon");
        collection.add("Fan");
        System.out.println("集合的大小:" + collection.size());
        
        //用Iterator遍历
        Iterator iterator = collection.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }
        System.out.println();
        
        //删除指定的元素
        collection.remove(false);
        
        //用foreach遍历集合
        System.out.println("删除元素后集合的大小:" + collection.size());
        for (Object object : collection) {
            System.out.println(object);
        }
        System.out.println();        
        
        Collection collection2 = new HashSet();
        collection2.add("Cocoon");
        collection2.add(100);
        
        //判断一个集合是否为另一个集合的子集
        System.out.println("collection2 是否为 collection的子集:" 
                + collection.containsAll(collection2));
        
        //判断一个集合中是否包含某个元素
        System.out.println("collection 是否包含 \"Cocoon\"字符串:"
                + collection.contains("Cocoon"));
        
        //求两个集合的差 A-B
        collection.removeAll(collection2);
        System.out.println("collection - collection2 = " + collection);
        
        //求两个集合的并:A+B
        collection.addAll(collection2);
        System.out.println("collection + collection2 = " + collection);
        
        //求两个集合的∩: A∩B
        collection.retainAll(collection2);
        System.out.println("collection ∩ collection2 = " + collection);
        
        //清空collection中所有的元素
        collection.clear();
        System.out.println("清空后collection的大小为:" + collection.size());
        System.out.println("collection = " + collection);
    }
}
输出的结果:


集合的大小:4
false
Cocoon
Fan

删除元素后集合的大小:3
Cocoon
Fan

collection2 是否为 collection的子集:true
collection 是否包含 "Cocoon"字符串:true
collection - collection2 = [Fan]
collection + collection2 = [Fan, 100, Cocoon]
collection ∩ collection2 = [100, Cocoon]
清空后collection的大小为:0
collection = []

另外在使用Iterator接口遍历集合元素的时候常用到下面三个方法
    · boolean hasNext():如果被迭代的集合元素还没有被遍历,则返回true
    · Object next():返回集合里的下一个元素
    · void remove(): 删除集合里面上一次next方法返回的元素
  实例见上面的19行代码。

  在使用Iterator接口时应注意:
    · Iterator仅用来遍历集合,它本身并不提供盛放对象的能力,如果需要创建Iterator对象,则应该有一个迭代的集合。
    · Iterator对集合元素进行迭代时并不是把集合元素本身传给课迭代器,而是把集合元素的值传给了迭代变量,所以修改迭代变量的值并不会对集合元素本身产生影响。
    · 当使用Iterator迭代访问Collection集合元素是,Collection集合里的元素不能被改变,只有通过Iterator的remove()方法删除上一次next方法返回的集合元素。
如在Iterator里面修改Collection集合里元素的值

//会报java.util.ConcurrentModificationException异常
collection.remove(iterator.next());
则会报出java.util.ConcurrentModificationException异常。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章