Java集合框架的知識(shí)總結(jié)
說(shuō)明:先從整體介紹了Java集合框架包含的接口和類,然后總結(jié)了集合框架中的一些基本知識(shí)和關(guān)鍵點(diǎn),并結(jié)合實(shí)例進(jìn)行簡(jiǎn)單分析。
一、綜述
所有集合類都位于java.util包下。集合中只能保存對(duì)象(保存對(duì)象的引用變量)。(數(shù)組既可以保存基本類型的數(shù)據(jù)也可以保存對(duì)象)。
當(dāng)我們把一個(gè)對(duì)象放入集合中后,系統(tǒng)會(huì)把所有集合元素都當(dāng)成Object類的實(shí)例進(jìn)行處理。從JDK1.5以后,這種狀態(tài)得到了改進(jìn):可以使用泛型來(lái)限制集合里元素的類型,并讓集合記住所有集合元素的類型(參見(jiàn)具體泛型的內(nèi)容)。
Java的集合類主要由兩個(gè)接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,這兩個(gè)接口又包含了一些接口或?qū)崿F(xiàn)類。
Set和List接口是Collection接口派生的兩個(gè)子接口,Queue是Java提供的隊(duì)列實(shí)現(xiàn),類似于List。
Map實(shí)現(xiàn)類用于保存具有映射關(guān)系的數(shù)據(jù)(key-value)。
Set、List和Map可以看做集合的三大類。
List集合是有序集合,集合中的元素可以重復(fù),訪問(wèn)集合中的元素可以根據(jù)元素的索引來(lái)訪問(wèn)。
Set集合是無(wú)序集合,集合中的元素不可以重復(fù),訪問(wèn)集合中的元素只能根據(jù)元素本身來(lái)訪問(wèn)(也是不能集合里元素不允許重復(fù)的原因)。
Map集合中保存Key-value對(duì)形式的元素,訪問(wèn)時(shí)只能根據(jù)每項(xiàng)元素的key來(lái)訪問(wèn)其value。
對(duì)于Set、List和Map三種集合,最常用的實(shí)現(xiàn)類分別是HashSet、ArrayList和HashMap三個(gè)實(shí)現(xiàn)類。(并發(fā)控制的集合類,以后有空研究下)。
二、Collection接口
Collection接口是List、Set和Queue接口的父接口,同時(shí)可以操作這三個(gè)接口。
Collection接口定義操作集合元素的具體方法大家可以參考API文檔,這里通過(guò)一個(gè)例子來(lái)說(shuō)明Collection的添加元素、刪除元素、返回集合中元素的個(gè)數(shù)以及清空集合元素的方法。
- public class TestCollection
- {
- public static void main(String[] args)
- {
- Collection c = new ArrayList();
- //添加元素
- c.add("孫悟空");
- //雖然集合里不能放基本類型的值,但Java支持自動(dòng)裝箱
- c.add(6);
- System.out.println("c集合的元素個(gè)數(shù)為:" + c.size());
- //刪除指定元素
- c.remove(6);
- System.out.println("c集合的元素個(gè)數(shù)為:" + c.size());
- //判斷是否包含指定字符串
- System.out.println("c集合的是否包含孫悟空字符串:" + c.contains("孫悟空"));
- c.add("輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn)");
- System.out.println("c集合的元素:" + c);
- Collection books = new HashSet();
- books.add("輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn)");
- books.add("Struts2權(quán)威指南");
- System.out.println("c集合是否完全包含books集合?" + c.containsAll(books));
- //用c集合減去books集合里的元素
- c.removeAll(books);
- System.out.println("c集合的元素:" + c);
- //刪除c集合里所有元素
- c.clear();
- System.out.println("c集合的元素:" + c);
- //books集合里只剩下c集合里也同時(shí)包含的元素
- books.retainAll(c);
- System.out.println("books集合的元素:" + books);
- }
- }
程序輸出結(jié)果:
c集合的元素個(gè)數(shù)為:2 c集合的元素個(gè)數(shù)為:1 c集合的是否包含孫悟空字符串:true c集合的元素:[孫悟空, 輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn)] c集合是否完全包含books集合?false c集合的元素:[孫悟空] c集合的元素:[] books集合的元素:[] |
三、兩種遍歷集合的方法Iterator接口和foreach循環(huán)
1、Iterator接口
Iterator也是Java集合框架的成員,主要用于遍歷(即迭代訪問(wèn))Collection集合中的元素,也稱為迭代器。
提供的三種方法:
boolean hasNext():返回集合里的下一個(gè)元素。
Object next():返回集合里下一個(gè)元素。
void remove();刪除集合里上一次next方法返回的元素。
- public class TestIterator
- {
- public static void main(String[] args)
- {
- //創(chuàng)建一個(gè)集合
- Collection books = new HashSet();
- books.add("輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn)");
- books.add("Struts2權(quán)威指南");
- books.add("基于J2EE的Ajax寶典");
- //獲取books集合對(duì)應(yīng)的迭代器
- Iterator it = books.iterator();
- while(it.hasNext())
- {
- //未使用泛型,需要強(qiáng)制轉(zhuǎn)換
- String book = (String)it.next();
- System.out.println(book);
- if (book.equals("Struts2權(quán)威指南"))
- {
- it.remove();
- //使用Iterator迭代過(guò)程中,不可修改集合元素,下面代碼引發(fā)異常
- //books.remove(book);
- }
- //對(duì)book變量賦值,不會(huì)改變集合元素本身
- book = "測(cè)試字符串";
- }
- System.out.println(books);
- }
- }
程序運(yùn)行結(jié)果:
Struts2權(quán)威指南 基于J2EE的Ajax寶典 輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn) [基于J2EE的Ajax寶典, 輕量級(jí)J2EE企業(yè)應(yīng)用實(shí)戰(zhàn)] |
說(shuō)明:
(1)通過(guò)語(yǔ)句“book = "測(cè)試字符串"; ”對(duì)迭代變量book進(jìn)行賦值時(shí),當(dāng)我們?cè)俅屋敵鯾ooks集合時(shí),集合里的元素沒(méi)有任何變化。即當(dāng)使用Iterator對(duì)集合元素進(jìn)行迭代時(shí),Iterator并不是把集合元素本身傳給迭代變量,而是把集合元素的值傳給了迭代變量。
(2)當(dāng)使用Iterator來(lái)訪問(wèn)Collection集合元素時(shí),只有通過(guò)Iterator的remove方法刪除(it.remove();)上一次next方法返回的集合元素才可以給集合中添加元素(book = "測(cè)試字符串"; )。否則引發(fā)java.util.ConcurrentModificationExcption異常。
2、使用foreach循環(huán)遍歷集合元素。
格式:for(元素類型 t 元素變量 x : 遍歷對(duì)象A) {
// 程序塊
}
說(shuō)明:
(1)foreach簡(jiǎn)化了對(duì)數(shù)組和集合的遍歷,如果不希望遍歷整個(gè)集合,或者在循環(huán)內(nèi)部需要操作下標(biāo)值就需要使用傳統(tǒng)的for循環(huán)。
(2)簡(jiǎn)化了編程,提高了代碼的可讀性和安全性(不用怕數(shù)組越界)。
(3)foreach一般結(jié)合泛型使用
實(shí)例應(yīng)用:
- public class TestArray {
- public static void main(String args[]) {
- TestArray test = new TestArray();
- test.test1();
- test.listToArray();
- test.testArray3();
- }
- /**
- * foreach語(yǔ)句輸出一維數(shù)組
- */
- public void test1() {
- // 定義并初始化一個(gè)數(shù)組
- int arr[] = { 2, 3, 1 };
- System.out.println("----1----排序前的一維數(shù)組");
- for (int x : arr) {
- System.out.println(x); // 逐個(gè)輸出數(shù)組元素的值
- }
- // 對(duì)數(shù)組排序
- Arrays.sort(arr);
- // 利用java新特性for each循環(huán)輸出數(shù)組
- System.out.println("----1----排序后的一維數(shù)組");
- for (int x : arr) {
- System.out.println(x); // 逐個(gè)輸出數(shù)組元素的值
- }
- }
- /**
- * 集合轉(zhuǎn)換為一維數(shù)組
- */
- public void listToArray() {
- // 創(chuàng)建List并添加元素
- List<String> list = new ArrayList<String>();
- list.add("1");
- list.add("3");
- list.add("4");
- // 利用froeach語(yǔ)句輸出集合元素
- System.out.println("----2----froeach語(yǔ)句輸出集合元素");
- for (String x : list) {
- System.out.println(x);
- }
- // 將ArrayList轉(zhuǎn)換為數(shù)組
- Object s[] = list.toArray();
- // 利用froeach語(yǔ)句輸出集合元素
- System.out.println("----2----froeach語(yǔ)句輸出集合轉(zhuǎn)換而來(lái)的數(shù)組元素");
- for (Object x : s) {
- System.out.println(x.toString()); // 逐個(gè)輸出數(shù)組元素的值
- }
- }
- /**
- * foreach輸出二維數(shù)組測(cè)試
- */
- public void testArray2() {
- int arr2[][] = { { 4, 3 }, { 1, 2 } };
- System.out.println("----3----foreach輸出二維數(shù)組測(cè)試");
- for (int x[] : arr2) {
- for (int e : x) {
- System.out.println(e); // 逐個(gè)輸出數(shù)組元素的值
- }
- }
- }
- /**
- * foreach輸出三維數(shù)組
- */
- public void testArray3() {
- int arr[][][] = { { { 1, 2 }, { 3, 4 } }, { { 5, 6 }, { 7, 8 } } };
- System.out.println("----4----foreach輸出三維數(shù)組測(cè)試");
- for (int[][] a2 : arr) {
- for (int[] a1 : a2) {
- for (int x : a1) {
- System.out.println(x);
- }
- }
- }
- }
- }
程序運(yùn)行結(jié)果:
----1----排序前的一維數(shù)組 2 3 1 ----1----排序后的一維數(shù)組 1 2 3 ----2----froeach語(yǔ)句輸出集合元素 1 3 4 ----2----froeach語(yǔ)句輸出集合轉(zhuǎn)換而來(lái)的數(shù)組元素 1 3 4 ----4----foreach輸出三維數(shù)組測(cè)試 1 2 3 4 5 6 7 8 |
感想:
這篇先寫(xiě)到這里,后續(xù)文章將會(huì)介紹其余集合接口和類的詳細(xì)知識(shí)。
這是自己寫(xiě)博客的第一篇文章,雖然很多內(nèi)容都是借鑒高手的,但是從他們的字里行間可以看出他們對(duì)技術(shù)的癡迷和研究的深入。
我從接觸Java到現(xiàn)在也就一年多時(shí)間,我深深被Java的一些程序表達(dá)方式所吸引。感覺(jué)它的語(yǔ)言風(fēng)格更接近我們自然語(yǔ)言的表述。
在程序中表達(dá)自己的思想何嘗不是一件暢事。
雖然斷斷續(xù)續(xù)的自學(xué)了一些Java知識(shí),現(xiàn)在也可以看懂Java的大部分代碼,但是要是自己去寫(xiě)出那些高深的代碼,感覺(jué)還是有些棘手。
聽(tīng)大師說(shuō),語(yǔ)言是用來(lái)思考的。
要是學(xué)會(huì)了用Java語(yǔ)言進(jìn)行思考,那么一定可以小有所成。
現(xiàn)在給自己制定了一個(gè)計(jì)劃,就是從寫(xiě)博客來(lái)提高自己學(xué)習(xí)Java的積極性。
首先是一些基礎(chǔ)知識(shí)的總結(jié),結(jié)合一些實(shí)例表明知識(shí)的應(yīng)用。
我想這會(huì)持續(xù)很久,也是考驗(yàn)自己,提高自己的好機(jī)會(huì)。
正如我的博客標(biāo)題,用代碼闡釋人生的哲學(xué),從代碼中領(lǐng)悟人生,看清世事。
祝福每個(gè)奮斗在Java中的人們都可以找到最真的自己。
原文鏈接:http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html
【編輯推薦】
- Java與F#的并行程序處理對(duì)比
- Java并發(fā)編程之同步互斥問(wèn)題
- Java中String.format的用法
- 郵件功能開(kāi)發(fā):JavaMail
- 關(guān)于讀寫(xiě)鎖算法的Java實(shí)現(xiàn)及思考