亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

基于Java回顧之集合的總結概述

2019-11-26 16:07:32
字體:
來源:轉載
供稿:網友

Java中的集合主要集中在2部分,一部分是java.util包中,一部分是java.util.concurrent中,后者是在前者的基礎上,定義了一些實現了同步功能的集合。

這篇文章主要關注java.util下的各種集合對象。Java中的集合對象可以粗略的分為3類:List、Set和Map。對應的UML圖如下(包括了java.util下大部分的集合對象):

Collection概述

Java集合中的List和Set都從Collection出來,它是一個學習集合很不錯的入口,它包含了集合中通常需要有的操作:

    添加元素:add/addAll
    清空集合:clear
    刪除元素:remove/removeAll
    判斷集合中是否包含某元素:contains/containsAll
    判斷集合是否為空:isEmpty
    計算集合中元素的個數:size
    將集合轉換為數組:toArray
    獲取迭代器:iterator

我們來看一個簡單的例子,下面的代碼會返回一個集合,集合中的元素是隨機生成的整數:

復制代碼 代碼如下:

private static Collection initCollection()
 {
     Collection<Integer> collection = new ArrayList<Integer>();
     Random r = new Random();
     for (int i = 0 ; i < 5; i++)
     {
         collection.add(new Integer(r.nextInt(100)));
     }

     return collection;
 }

在對集合進行操作的過程中,遍歷是一個經常使用的操作,我們可以使用兩種方式對集合進行遍歷:

1) 使用迭代器對集合進行遍歷。正如上面描述Collection接口時所說,所有集合都會有一個迭代器,我們可以用它來遍歷集合。

復制代碼 代碼如下:

private static void accessCollectionByIterator(Collection<Integer> collection)
 {
     Iterator<Integer> iterator = collection.iterator();
     System.out.println("The value in the list:");
     while(iterator.hasNext())
     {
         System.out.println(iterator.next());
     }
 }

2)使用foreach遍歷集合。
復制代碼 代碼如下:

private static void accessCollectionByFor(Collection<Integer> collection)
 {
     System.out.println("The value in the list:");
     for(Integer value : collection)
     {
         System.out.println(value);
     }
 }

List

Java中的List是對數組的有效擴展,它是這樣一種結構,如果不使用泛型,它可以容納任何類型的元素,如果使用泛型,那么它只能容納泛型指定的類型的元素。和數組相比,List的容量是可以動態擴展的。

List中的元素是可以重復的,里面的元素是“有序”的,這里的“有序”,并不是排序的意思,而是說我們可以對某個元素在集合中的位置進行指定。

List中常用的集合對象包括:ArrayList、Vector和LinkedList,其中前兩者是基于數組來進行存儲,后者是基于鏈表進行存儲。其中Vector是線程安全的,其余兩個不是線程安全的。

List中是可以包括null的,即使是使用了泛型。

ArrayList可能是我們平時用到的最多的集合對象了,在上述的示例代碼中,我們也是使用它來實例化一個Collection對象,在此不再贅述。
Vector

Vector的示例如下,首先我們看如何生成和輸出Vector:

復制代碼 代碼如下:

private static void vectorTest1()
 {
     List<Integer> list = new Vector<Integer>();
     for (int i = 0 ; i < 5; i++)
     {
         list.add(new Integer(100));
     }
     list.add(null);
     System.out.println("size of vector is " + list.size());
     System.out.println(list);
 }

它的元素中,既包括了重復元素,也包括了null,輸出結果如下:
復制代碼 代碼如下:

size of vector is 6
[100, 100, 100, 100, 100, null]

下面的示例,演示了Vector中的一些常用方法:
復制代碼 代碼如下:

private static void vectorTest2()
 {
     Vector<Integer> list = new Vector<Integer>();
     Random r = new Random();
     for (int i = 0 ; i < 10; i++)
     {
         list.add(new Integer(r.nextInt(100)));
     }
     System.out.println("size of vector is " + list.size());
     System.out.println(list);
     System.out.println(list.firstElement());
     System.out.println(list.lastElement());
     System.out.println(list.subList(3, 8));
     List<Integer> temp = new ArrayList<Integer>();
     for(int i = 4; i < 7; i++)
     {
         temp.add(list.get(i));
     }
     list.retainAll(temp);
     System.out.println("size of vector is " + list.size());
     System.out.println(list);
 }

它的輸出結果如下:
復制代碼 代碼如下:

size of vector is 10
[39, 41, 20, 9, 29, 32, 54, 12, 94, 82]


[9, 29, 32, 54, 12]
size of vector is 3
[29, 32, 54]


LinkedList

LinkedList使用鏈表來存儲數據,它的示例代碼如下:

復制代碼 代碼如下:

LinkedList示例
 private static void linkedListTest1()
 {
     LinkedList<Integer> list = new LinkedList<Integer>();
     Random r = new Random();
     for (int i = 0 ; i < 10; i++)
     {
         list.add(new Integer(r.nextInt(100)));
     }
     list.add(null);
     System.out.println("size of linked list is " + list.size());
     System.out.println(list);
     System.out.println(list.element());
     System.out.println(list.getFirst());
     System.out.println(list.getLast());
     System.out.println(list.peek());
     System.out.println(list.peekFirst());
     System.out.println(list.peekLast());
     System.out.println(list.poll());
     System.out.println(list.pollFirst());
     System.out.println(list.pollLast());
     System.out.println(list.pop());
     list.push(new Integer(100));
     System.out.println("size of linked list is " + list.size());
     System.out.println(list);
 }

這里列出了LinkedList常用的各個方法,從方法名可以看出,LinkedList也可以用來實現棧和隊列。

輸出結果如下:

復制代碼 代碼如下:

size of linked list is 11
[17, 21, 5, 84, 19, 57, 68, 26, 27, 47, null]


null


null


null

size of linked list is 8
[100, 84, 19, 57, 68, 26, 27, 47]


Set

Set 和List類似,都是用來存儲單個元素,單個元素的數量不確定。但Set不能包含重復元素,如果向Set中插入兩個相同元素,那么后一個元素不會被插入。

Set可以大致分為兩類:不排序Set和排序Set,不排序Set包括HashSet和LinkedHashSet,排序Set主要指TreeSet。其中HashSet和LinkedHashSet可以包含null。
HashSet

HashSet是由Hash表支持的一種集合,它不是線程安全的。

我們來看下面的示例,它和Vector的第一個示例基本上是相同的:

復制代碼 代碼如下:

private static void hashSetTest1()
 {
     Set<Integer> set = new HashSet<Integer>();

     for (int i = 0; i < 3; i++)
     {
         set.add(new Integer(100));
     }
     set.add(null);

     System.out.println("size of set is " + set.size());
     System.out.println(set);
 }

這里,HashSet中既包含了重復元素,又包含了null,和Vector不同,這里的輸出結果如下:
復制代碼 代碼如下:

size of set is 2
[null, 100]

對于HashSet是如何判斷兩個元素是否是重復的,我們可以深入考察一下。Object中也定義了equals方法,對于HashSet中的元素,它是根據equals方法來判斷元素是否相等的,為了證明這一點,我們可以定義個“不正?!钡念愋停?BR>
復制代碼 代碼如下:

定義MyInteger對象

class MyInteger
{
    private Integer value;

    public MyInteger(Integer value)
    {
        this.value = value;
    }

    public String toString()
    {
        return String.valueOf(value);
    }

    public int hashCode()
    {
        return 1;
    }

    public boolean equals(Object obj)
    {
        return true;
    }
}


可以看到,對于MyInteger來說,對于任意兩個實例,我們都認為它是不相等的。

下面是對應的測試方法:

復制代碼 代碼如下:

private static void hashSetTest2()
 {
     Set<MyInteger> set = new HashSet<MyInteger>();

     for (int i = 0; i < 3; i++)
     {
         set.add(new MyInteger(100));
     }

     System.out.println("size of set is " + set.size());
     System.out.println(set);
 }

它的輸出結果如下:
復制代碼 代碼如下:

size of set is 3
[100, 100, 100]

可以看到,現在HashSet里有“重復”元素了,但對于MyInteger來說,它們不是“相同”的。
TreeSet

TreeSet是支持排序的一種Set,它的父接口是SortedSet。

我們首先來看一下TreeSet都有哪些基本操作:

復制代碼 代碼如下:

private static void treeSetTest1()
 {
     TreeSet<Integer> set = new TreeSet<Integer>();

     Random r = new Random();
     for (int i = 0 ; i < 5; i++)
     {
         set.add(new Integer(r.nextInt(100)));
     }

     System.out.println(set);
     System.out.println(set.first());
     System.out.println(set.last());
     System.out.println(set.descendingSet());
     System.out.println(set.headSet(new Integer(50)));
     System.out.println(set.tailSet(new Integer(50)));
     System.out.println(set.subSet(30, 60));
     System.out.println(set.floor(50));
     System.out.println(set.ceiling(50));
 }

它的輸出結果如下:
復制代碼 代碼如下:

[8, 42, 48, 49, 53]


[53, 49, 48, 42, 8]
[8, 42, 48, 49]
[53]
[42, 48, 49, 53]


TreeSet中的元素,一般都實現了Comparable接口,默認情況下,對于Integer來說,SortedList是采用升序來存儲的,我們也可以自定義Compare方式,例如以降序的方式來存儲。

下面,我們首先重新定義Integer:

復制代碼 代碼如下:

定義MyInteger2對象
 class MyInteger2 implements Comparable
 {
     public int value;

     public MyInteger2(int value)
     {
         this.value = value;
     }

     public int compareTo(Object arg0)
     {
         MyInteger2 temp = (MyInteger2)arg0;
         if (temp == null) return -1;
         if (temp.value > this.value)
         {
             return 1;
         }
         else if (temp.value < this.value)
         {
             return -1;
         }
         return 0;
     }

     public boolean equals(Object obj)
     {
         return compareTo(obj) == 0;
     }

     public String toString()
     {
         return String.valueOf(value);
     }
 }

下面是測試代碼:
復制代碼 代碼如下:

private static void treeSetTest2()
 {
     TreeSet<Integer> set1 = new TreeSet<Integer>();
     TreeSet<MyInteger2> set2 = new TreeSet<MyInteger2>();
     Random r = new Random();
     for (int i = 0 ; i < 5; i++)
     {
         int value = r.nextInt(100);
         set1.add(new Integer(value));
         set2.add(new MyInteger2(value));
     }
     System.out.println("Set1 as below:");
     System.out.println(set1);
     System.out.println("Set2 as below:");
     System.out.println(set2);
 }

代碼的運行結果如我們所預期的那樣,如下所示:
復制代碼 代碼如下:

Set1 as below:
[13, 41, 42, 45, 61]
Set2 as below:
[61, 45, 42, 41, 13]

Map

Map中存儲的是“鍵值對”,和Set類似,Java中的Map也有兩種:排序的和不排序的,不排序的包括HashMap、Hashtable和LinkedHashMap,排序的包括TreeMap。
非排序Map

HashMap和Hashtable都是采取Hash表的方式進行存儲,HashMap不是線程安全的,Hashtable是線程安全的,我們可以把HashMap看做是“簡化”版的Hashtable。

HashMap是可以存儲null的,無論是對Key還是對Value。Hashtable是不可以存儲null的。

無論HashMap還是Hashtable,我們觀察它的構造函數,就會發現它可以有兩個參數:initialCapacity和loadFactor,默認情況下,initialCapacity等于16,loadFactor等于0.75。這和Hash表中可以存放的元素數目有關系,當元素數目超過initialCapacity*loadFactor時,會觸發rehash方法,對hash表進行擴容。如果我們需要向其中插入過多元素,需要適當調整這兩個參數。

我們首先來看HashMap的示例:

復制代碼 代碼如下:

private static void hashMapTest1()
 {
     Map<Integer,String> map = new HashMap<Integer, String>();

     map.put(new Integer(1), "a");
     map.put(new Integer(2), "b");
     map.put(new Integer(3), "c");

     System.out.println(map);
     System.out.println(map.entrySet());
     System.out.println(map.keySet());
     System.out.println(map.values());
 }

這會輸出HashMap里的元素信息,如下所示。
復制代碼 代碼如下:

{1=a, 2=b, 3=c}
[1=a, 2=b, 3=c]
[1, 2, 3]
[a, b, c]

下面的示例是對null的演示:
復制代碼 代碼如下:

private static void hashMapTest2()
 {
     Map<Integer,String> map = new HashMap<Integer, String>();

     map.put(null, null);
     map.put(null, null);
     map.put(new Integer(4), null);
     map.put(new Integer(5), null);

     System.out.println(map);
     System.out.println(map.entrySet());
     System.out.println(map.keySet());
     System.out.println(map.values());
 }

執行結果如下:
復制代碼 代碼如下:

{null=null, 4=null, 5=null}
[null=null, 4=null, 5=null]
[null, 4, 5]
[null, null, null]

接下來我們演示Hashtable,和上述兩個示例基本上完全一樣(代碼不再展開):
復制代碼 代碼如下:

Hashtable示例
 private static void hashTableTest1()
 {
     Map<Integer,String> table = new Hashtable<Integer, String>();

     table.put(new Integer(1), "a");
     table.put(new Integer(2), "b");
     table.put(new Integer(3), "c");

     System.out.println(table);
     System.out.println(table.entrySet());
     System.out.println(table.keySet());
     System.out.println(table.values());
 }

 private static void hashTableTest2()
 {
     Map<Integer,String> table = new Hashtable<Integer, String>();

     table.put(null, null);
     table.put(null, null);
     table.put(new Integer(4), null);
     table.put(new Integer(5), null);

     System.out.println(table);
     System.out.println(table.entrySet());
     System.out.println(table.keySet());
     System.out.println(table.values());
 }

執行結果如下:
復制代碼 代碼如下:

{3=c, 2=b, 1=a}
[3=c, 2=b, 1=a]
[3, 2, 1]
[c, b, a]
Exception in thread "main" java.lang.NullPointerException
    at java.util.Hashtable.put(Unknown Source)
    at sample.collections.MapSample.hashTableTest2(MapSample.java:61)
    at sample.collections.MapSample.main(MapSample.java:11)

可以很清楚的看到,當我們試圖將null插入到hashtable中時,報出了空指針異常。
排序Map

排序Map主要是指TreeMap,它對元素增、刪、查操作時的時間復雜度都是O(log(n))。它不是線程安全的。

它的特點和TreeSet非常像,這里不再贅述。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕一区二区精品| 欧美黑人巨大精品一区二区| 欧美日韩国产精品一区二区三区四区| 91在线视频导航| 91久久国产综合久久91精品网站| 精品香蕉在线观看视频一| 91九色视频在线| www.99久久热国产日韩欧美.com| 国产成人精品久久久| 亚洲精品v天堂中文字幕| 久久亚洲精品一区| 久久久电影免费观看完整版| 日韩视频免费在线| 91精品国产综合久久香蕉的用户体验| 日韩免费观看av| 91精品视频专区| 国产精品视频自在线| 日韩av男人的天堂| 国产又爽又黄的激情精品视频| 欧美日韩国产综合新一区| 深夜福利一区二区| 亚洲一区二区三区成人在线视频精品| 国产不卡精品视男人的天堂| 九九视频直播综合网| 欧美日韩xxxxx| 日韩av在线免费看| 久久久久久999| 欧美高清在线观看| 欧美在线视频免费播放| 欧美成人手机在线| 91久久久久久| 成人啪啪免费看| 日本免费在线精品| 国产成人高清激情视频在线观看| 欧美日韩在线视频一区二区| 国产精品极品美女在线观看免费| 日韩欧美精品在线观看| 欧美一级大片在线观看| 日韩av电影免费观看高清| 久久久久一本一区二区青青蜜月| 在线播放日韩专区| 一区二区三区四区视频| 国产精品久久精品| 国外成人在线播放| 国产精品狼人色视频一区| 久久久久国产精品免费网站| 欧美在线视频在线播放完整版免费观看| 久久精品久久久久久| 欧美黄色片视频| 亚洲成年人在线播放| 亚洲欧洲成视频免费观看| 91麻豆国产精品| 久久久久久综合网天天| 69久久夜色精品国产69乱青草| 国产欧美精品在线播放| 国产精品黄页免费高清在线观看| 成人黄色av免费在线观看| 日韩久久午夜影院| 北条麻妃一区二区在线观看| 色爱av美腿丝袜综合粉嫩av| 久久久伊人日本| 丝袜美腿精品国产二区| 正在播放欧美一区| 91亚洲永久免费精品| 亚洲天堂av在线播放| 亚洲精品98久久久久久中文字幕| 中文字幕日韩视频| 亚洲自拍在线观看| 97精品国产97久久久久久春色| 国产91露脸中文字幕在线| 一区二区欧美亚洲| 欧美福利视频在线观看| 亚洲国产精品系列| 欧美日韩裸体免费视频| 国产精品igao视频| 久久久日本电影| 欧美激情在线观看视频| 国产欧美日韩中文字幕| www.欧美免费| 欧美另类99xxxxx| 国产精品∨欧美精品v日韩精品| 久久久久日韩精品久久久男男| 亚洲自拍偷拍色图| 国产精品99蜜臀久久不卡二区| 中文字幕综合一区| 日韩福利伦理影院免费| 欧美视频第一页| 亚洲韩国青草视频| 中文字幕亚洲在线| 97精品国产97久久久久久| 黑人极品videos精品欧美裸| 午夜精品久久久久久久白皮肤| 日韩精品视频在线播放| 亚洲成人av中文字幕| 成人在线视频网站| 色综合久久精品亚洲国产| 亚洲天堂av综合网| 国产成人精品亚洲精品| 精品福利在线看| 国产一区在线播放| 久久免费视频网站| 欧美一级电影免费在线观看| 亚洲最新av在线网站| 日韩电影免费在线观看中文字幕| 狠狠躁天天躁日日躁欧美| 久久777国产线看观看精品| 久久久精品一区| 一区二区亚洲精品国产| 日韩综合视频在线观看| 色妞在线综合亚洲欧美| 欧美黑人一级爽快片淫片高清| 亚洲第一福利在线观看| 国产精品一区av| 国产精品爽爽爽爽爽爽在线观看| 国产精品久久久久av| 亚洲国产美女久久久久| 麻豆乱码国产一区二区三区| 国产亚洲欧美另类中文| 俺去亚洲欧洲欧美日韩| 国内精品小视频| 亚洲а∨天堂久久精品9966| 北条麻妃一区二区三区中文字幕| 亚洲第一免费网站| 91超碰caoporn97人人| 日韩中文在线视频| 在线视频精品一| 成人欧美一区二区三区在线湿哒哒| 91久久在线播放| 日本视频久久久| 国产成人精品免高潮费视频| 久久久久久久久久久免费精品| 欧美寡妇偷汉性猛交| 亚洲精品一区在线观看香蕉| 欧美日韩国产一区中文午夜| 亚洲性日韩精品一区二区| 久久久久成人网| 亚洲国产一区自拍| 久久精品视频在线| 亚洲国产精品成人va在线观看| 亚洲精品成人久久久| 国产主播在线一区| 国产精品久久久久久久久久新婚| 国产做受高潮69| 久久青草福利网站| 午夜精品久久久久久久99黑人| 国产视频自拍一区| 国产精品自产拍在线观| 一区二区在线视频| 九九热视频这里只有精品| www日韩中文字幕在线看| 欧美成人亚洲成人日韩成人| 日韩精品视频在线观看网址| 国产精品自产拍高潮在线观看| 不卡av电影在线观看| 国产男女猛烈无遮挡91| 日本精品久久久久久久| 亚洲国产美女精品久久久久∴| 国产精品18久久久久久麻辣| 黑人巨大精品欧美一区二区免费| 国产精品一区二区三区成人| 91九色精品视频| 亚洲国产精品一区二区久| 性色av一区二区咪爱| www.欧美精品一二三区|