我思故我強

          java Collection 學(xué)習(xí)筆記


          支持類集的接口如下:
          Collection
          List
          Set
          SortedSet
          Comparator 定義兩個對象如何比較
          Iterator 枚舉類集中的對象
          ListIterator枚舉類集中的對象
          Collection接口(省略常用的方法)
          Boolean add(Object obj) 添加一個Object元素
          boolean addAll(Collection c)
          boolean contains(Object obj)? 判斷obj是否是調(diào)用類集的一個元素(屬于)
          boolean containsAll(Collection c)? 判斷c是否是調(diào)用類集的子集(包含)
          boolean equals(Collection c) 判斷c是否與調(diào)用類集相等
          int hashCode() 返回調(diào)用類集的hash碼
          Iterator iterator() 返回調(diào)用類集的迭代程序
          boolean removeAll(Collection c) 從調(diào)用類集中去掉所有c中包含的元素(差集)
          boolean retainAll(Collection c) 從調(diào)用類集中去掉包含在c中以外的元素(補集)
          Object[] toArray() 返回類集的元素組成的數(shù)組
          ?
          Void clear()
          boolean isEmpty()
          int size()

          類集包含一個add(Object obj)方法,因此可以包含任意Object數(shù)據(jù),但是不能直接存儲:int,char,Double等數(shù)據(jù)。可以使用下面的方法實現(xiàn):
          ArrayList a=new ArrayList();
          a.add(new Integer(1));
          a.add(new Integer(2));
          ……

          當(dāng)類集不能被修改時,可能引發(fā) UnsupportedOperationException異常。企圖將一個不兼容的對象加入到一個類集中時可能引發(fā)ClassCastException異常。

          List接口(從Collection繼承而來,使用基于0的下標(biāo))
          void add(int index,Object obj) 插入點以后的元素將后移
          boolean addAll(int index,Collection c) 如果調(diào)用列表改變了,返回true,否則返回false
          Object get(int index)
          int indexOf(Object obj) 返回obj對象在列表中的索引,不存在返回-1
          int lastIndexOf(Object obj) 返回obj在列表中的最后一個實例的下標(biāo),不存在返回-1
          ListIterator listIterator()
          ListIterator listIterator(int index) 返回index開始的迭代程序
          Object set(int index,Object obj) 對列表index處的值進行修改
          List subList(int start,int end) 從start到end-1
          ?

          Set接口(從Collection派生,沒有定義新的方法)
          Set不允許有重復(fù)的元素。
          對Set調(diào)用add(Object obj)方法,如果obj已經(jīng)存在集合中,將返回false。

          SortedSet接口
          Comparator comparator() 返回調(diào)用排序集合的比較函數(shù),如果改集合使用自然順序,則返回null
          Object first() 返回被排序集合的第一個元素
          SortedSet headSet(Object end) 返回一個包含小于end元素的SortedSet
          Object last() 返回調(diào)用排序集合的最后一個元素
          SortedSet subSet(Object start,Object end) 包括從start到end-1
          SortedSet tailSet(Object start) 返回包含大于等于start的元素
          ?

          ArrayList擴展AstractList類,并執(zhí)行List接口。ArrayList支持動態(tài)長度的數(shù)組。
          LinkList擴展了AbstractSequentialList,執(zhí)行List接口。提供連接列表。
          HashSet擴展AbstractSet實現(xiàn)Set接口,元素沒有順序。對于大集合提供常量級基本操作。
          TreeSet使用樹來存儲的Set,對象按升序存儲。訪問和檢索非常快。

          iterator實現(xiàn)Iterator接口或者ListIterator接口。
          Iterator接口
          boolean hasNext()
          Object next() 如果沒有下一個元素則引發(fā)NoSuchElementException異常。
          void remove() 刪除當(dāng)前元素,如果試圖在調(diào)用next()方法后調(diào)用remove()方法則引發(fā)IllegalStateException異常。
          ?
          ?

          ListIterator接口
          void add(Object obj) 將一個元素插入到當(dāng)前元素之前,調(diào)用next()方法將返回該元素。
          boolean hasNext()
          boolean hasPrevious()
          Object next() 如果不存在引發(fā)NoSuchElementException
          int nextIndex() 如果不存在返回列表的大小
          void remove()
          void set(Object obj) 修改當(dāng)前元素

          public void test1() {
          ? ArrayList al = new ArrayList();
          ? for (int i = 1; i < 10; i++) {
          ? al.add("ArrayList Element:" + i);
          ? }
          ? Iterator itr = al.listIterator();
          ? while (itr.hasNext()) {
          ? Object obj = itr.next();
          ? System.out.println(obj);
          ? }
          ? }

          public void test2() {
          ? HashSet hs = new HashSet();
          ? System.out.println("HashSet");
          ? for (int i = 1; i < 10; i++) {
          ? hs.add("HashSet Element:" + i);
          ? }
          ? Iterator itr = hs.iterator();
          ? while (itr.hasNext()) {
          ? Object obj = itr.next();
          ? System.out.println(obj);
          ? }
          ? }

          ? public void test3() {
          ? TreeSet ts = new TreeSet();
          ? System.out.println("TreeSet");
          ? for (int i = 1; i < 10; i++) {
          ? ts.add("TreeSet Element:" + i);
          ? }
          ? Iterator itr = ts.iterator();
          ? while (itr.hasNext()) {
          ? Object obj = itr.next();
          ? System.out.println(obj);
          ? }
          ? }

          ? public void test4()
          ? {
          ? HashMap hm=new HashMap();
          ? for ( int i=0;i<10;i++)
          ? {
          ? hm.put("item"+i,"value"+i);
          ? }

          ? Set set=hm.entrySet();
          ? Iterator itr=set.iterator();
          ? while (itr.hasNext())
          ? {
          ? Map.Entry me=(Map.Entry)itr.next();
          ? System.out.println(me.getKey()+";"+me.getValue());
          ? }

          ? hm.put("item5","modifyed value");
          ? System.out.println(hm.get("item5") );

          ? set=hm.entrySet();
          ? itr=set.iterator();
          ? while (itr.hasNext())
          ? {
          ? Map.Entry me=(Map.Entry)itr.next();
          ? System.out.println(me.getKey()+";"+me.getValue());
          ? }

          ? }

          ?

          ?

          posted on 2007-09-13 16:29 李云澤 閱讀(439) 評論(0)  編輯  收藏 所屬分類: J2SE

          主站蜘蛛池模板: 乌兰浩特市| 商南县| 余江县| 安龙县| 湛江市| 富裕县| 定兴县| 吴旗县| 东源县| 秦安县| 建阳市| 江津市| 乌苏市| 兴安盟| 扎鲁特旗| 永济市| 南漳县| 镇平县| 陕西省| 郁南县| 定陶县| 铜鼓县| 黑山县| 新竹县| 泸溪县| 舒城县| 穆棱市| 巴林右旗| 柳州市| 西贡区| 平度市| 苏尼特右旗| 临桂县| 正蓝旗| 祥云县| 屯留县| 鄂伦春自治旗| 都匀市| 长顺县| 吉木萨尔县| 福安市|