码迷,mamicode.com
首页 > 编程语言 > 详细

Java 集合

时间:2015-12-02 12:21:33      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:

集合

集合类
    出现原因 //存储对象
    与数组区别 //数组长度固定 集合长度可变 数组可存储基本数据类型 集合只能存储对象
    特点 //可存储不同类型对象 长度可变

集合框架
集合容器因为内部的数据结构不同,有多种具体容器。
不断的向上抽取,就形成了集合框架。

框架的顶层Collection接口:

Collection的常见方法:

1,添加。
    boolean add(Object obj):
    boolean addAll(Collection coll):
    

2,删除。
    boolean remove(object obj):
    boolean removeAll(Collection coll);
    void clear();
    
3,判断:
    boolean contains(object obj):
    boolean containsAll(Colllection coll);
    boolean isEmpty():判断集合中是否有元素。

4,获取:
    int size():
    Iterator iterator():取出元素的方式:迭代器。
    该对象必须依赖于具体容器,因为每一个容器的数据结构都不同。
    所以该迭代器对象是在容器中进行内部实现的。
    对于使用容器者而言,具体的实现不重要,只要通过容器获取到该实现的迭代器的对象即可,
    也就是iterator方法。
    
    Iterator接口就是对所有的Collection容器进行元素取出的公共接口。
    其实就是抓娃娃游戏机中的夹子!
    
    
5,其他:
    boolean retainAll(Collection coll);取交集。
    Object[] toArray():将集合转成数组。

Demo1 CollectionDemo

public class CollectionDemo {
  public static void main(String[] args) {
    Collection coll = new ArrayList();

    // show(coll);

    Collection c1 = new ArrayList();
    Collection c2 = new ArrayList();
    show(c1, c2);

  }

  public static void show(Collection c1, Collection c2) {

    // 给c1添加元素。
    c1.add("abc1");
    c1.add("abc2");
    c1.add("abc3");
    c1.add("abc4");

    // 给c2添加元素。
    c2.add("abc1");
    c2.add("abc2");
    c2.add("abc3");
    c2.add("abc4");
    c2.add("abc5");

    System.out.println("c1:" + c1);
    System.out.println("c2:" + c2);

    // 演示addAll

    // c1.addAll(c2);//将c2中的元素添加到c1中。

    // 演示removeAll
    // boolean b = c1.removeAll(c2);//将两个集合中的相同元素从调用removeAll的集合中删除。
    // System.out.println("removeAll:"+b);

    // 演示containsAll
    // boolean b = c1.containsAll(c2);
    // System.out.println("containsAll:"+b);

    // 演示retainAll
    boolean b = c1.retainAll(c2);// 取交集,保留和指定的集合相同的元素,而删除不同的元素。
    // 和removeAll功能相反 。
    System.out.println("retainAll:" + b);
    System.out.println("c1:" + c1);

  }

  public static void show(Collection coll) {

    // 1,添加元素。add.
    coll.add("abc1");
    coll.add("abc2");
    coll.add("abc3");
    System.out.println(coll);

    // 2,删除元素。remove
    // coll.remove("abc2");//会改变集合的长度

    // 清空集合.
    // coll.clear();

    System.out.println(coll.contains("abc3"));

    System.out.println(coll);

  }
}

Demo2 迭代器

public class IteratorDemo {
  public static void main(String[] args) {

    Collection coll = new ArrayList();
    coll.add("abc1");
    coll.add("abc2");
    coll.add("abc3");
    coll.add("abc4");

    // System.out.println(coll);

    // 使用了Collection中的iterator()方法。 调用集合中的迭代器方法,是为了获取集合中的迭代器对象。
    // Iterator it = coll.iterator();
    // while(it.hasNext()){
    // System.out.println(it.next());
    // }

    for (Iterator it = coll.iterator(); it.hasNext();) {
      System.out.println(it.next());
    }

    // System.out.println(it.next());
    // System.out.println(it.next());
    // System.out.println(it.next());
    // System.out.println(it.next());
    // System.out.println(it.next());//java.util.NoSuchElementException

  }
}

Collection
    |--List:有序(存入和取出的顺序一致),元素都有索引(角标),元素可以重复。
    |--Set:元素不能重复,无序。

List:特有的常见方法:有一个共性特点就是都可以操作角标。
    
1,添加
    void add(index,element);
    void add(index,collection);

2,删除;
    Object remove(index):

3,修改:
    Object set(index,element);
   
4,获取:
    Object get(index);
    int indexOf(object);
    int lastIndexOf(object);
    List subList(from,to);
   
list集合是可以完成对元素的增删改查。

Demo3

public class ListDemo {
  public static void main(String[] args) {
    List list = new ArrayList();
    show(list);
  }

  public static void show(List list) {

    // 添加元素
    list.add("abc1");
    list.add("abc2");
    list.add("abc3");
    System.out.println(list);

    // 插入元素。
    // list.add(1,"abc9");

    // 删除元素。
    // System.out.println("remove:"+list.remove(2));

    // 修改元素。
    // System.out.println("set:"+list.set(1, "abc8"));

    // 获取元素。
    // System.out.println("get:"+list.get(0));

    // 获取子列表。
    // System.out.println("sublist:"+list.subList(1, 2));

    System.out.println(list);

  }
}

Demo4

public class ListDemo2 {
  public static void main(String[] args) {

    List list = new ArrayList();
//  show(list);
    
    list.add("abc1");
    list.add("abc2");
    list.add("abc3");
    
    System.out.println("list:"+list);
    ListIterator it = list.listIterator();//获取列表迭代器对象
    //它可以实现在迭代过程中完成对元素的增删改查。
    //注意:只有list集合具备该迭代功能.
    
    while(it.hasNext()){
      
      Object obj = it.next();
      
      if(obj.equals("abc2")){
        it.set("abc9");
      }
    }
//    System.out.println("hasNext:"+it.hasNext());
//    System.out.println("hasPrevious:"+it.hasPrevious());
    
    
    while(it.hasPrevious()){
      System.out.println("previous:"+it.previous());
    }
    System.out.println("list:"+list);
    
    /*Iterator it = list.iterator();
    while(it.hasNext()){
      
      Object obj = it.next();//java.util.ConcurrentModificationException
              //在迭代器过程中,不要使用集合操作元素,容易出现异常。
            //可以使用Iterator接口的子接口ListIterator来完成在迭代中对元素进行更多的操作。 
      
      if(obj.equals("abc2")){
        list.add("abc9");
      }
      else
        System.out.println("next:"+obj);
    }
    System.out.println(list);
    */

  }

  public static void show(List list) {
    
    list.add("abc1");
    list.add("abc2");
    list.add("abc3");
    list.add("abc4");
    
    Iterator it = list.iterator();
    while(it.hasNext()){
      System.out.println("next:"+it.next());
    }
    
    //list特有的取出元素的方式之一。
    
    for(int x=0; x<list.size(); x++){
      System.out.println("get:"+list.get(x));
    }
  }

}

List:
    |--Vector:内部是数组数据结构,是同步的。增删,查询都很慢!
    |--ArrayList:内部是数组数据结构,是不同步的。替代了Vector。查询的速度快。
    |--LinkedList:内部是链表数据结构,是不同步的。增删元素的速度很快。

Demo5 Vector中的elements()方法

public class VectorDemo {
  public static void main(String[] args) {

    Vector v = new Vector();
    
    v.addElement("abc1");
    v.addElement("abc2");
    v.addElement("abc3");
    v.addElement("abc4");
    
    Enumeration en = v.elements();
    while(en.hasMoreElements()){
      System.out.println("nextelment:"+en.nextElement());
    }
    
    Iterator it = v.iterator();
    
    while(it.hasNext()){
      System.out.println("next:"+it.next());
    }
    
  }
}

LinkedList:

    addFirst();
    addLast():
    jdk1.6
    offerFirst();
    offetLast();
   
    getFirst();.//获取但不移除,如果链表为空,抛出NoSuchElementException.
    getLast();
    jdk1.6
    peekFirst();//获取但不移除,如果链表为空,返回null.
    peekLast():
    
    removeFirst();//获取并移除,如果链表为空,抛出NoSuchElementException.
    removeLast();
    jdk1.6
    pollFirst();//获取并移除,如果链表为空,返回null.
    pollLast();

Demo6 LinkedListDemo

public class LinkedListDemo {
  public static void main(String[] args) {

    LinkedList link = new LinkedList();
    
    link.addFirst("abc1");
    link.addFirst("abc2");
    link.addFirst("abc3");
    link.addFirst("abc4");
//    System.out.println(link);
//    System.out.println(link.getFirst());//获取第一个但不删除。
//    System.out.println(link.getFirst());
    
//    System.out.println(link.removeFirst());//获取元素但是会删除。
//    System.out.println(link.removeFirst());
    
    while(!link.isEmpty()){
      System.out.println(link.removeLast());
    }
    
    
    System.out.println(link);
//    Iterator it = link.iterator();
//    while(it.hasNext()){
//      System.out.println(it.next());
//    }
  }
}

Demo7 请使用LinkedList来模拟一个堆栈或者队列数据结构

堆栈:先进后出 First In Last Out  FILO
队列:先进先出 First In First Out FIFO

public class LinkedTest {
  public static void main(String[] args) {
    
    DuiLie dl = new DuiLie();
    
    dl.myAdd("abc1");
    dl.myAdd("abc2");
    dl.myAdd("abc3");
    dl.myAdd("abc4");
    
    while(!dl.isNull()){
      System.out.println(dl.myGet());
    }
    
    
  }
}

class DuiLie {
  private LinkedList link;

  public DuiLie() {
    link = new LinkedList();
  }

  /**
   * 队列的添加元素的功能。
   */
  public void myAdd(Object obj) {
    link.addLast(obj);
  }

  public Object myGet() {
    return link.removeFirst();
  }

  public boolean isNull() {
    return link.isEmpty();
  }
}

 

Java 集合

标签:

原文地址:http://www.cnblogs.com/huanyi0723/p/5012527.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!