版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
JAVA中的集合框架學習內容
集合框架的概念Java語言中的集合Collection接口Set接口List接口Map接口目標掌握集合框架包含的內容掌握ArrayList和LinkedList的使用掌握HashMap的使用掌握Iterator的使用掌握泛型集合的使用學員1學員20如何存儲每天的新聞信息?如何存儲計算機專業(yè)課程的代碼與課程信息,能夠通過代碼方便地獲得課程信息?如果并不知道程序運行時會需要多少對象,或者需要更復雜方式存儲對象——可以使用Java集合框架一維數(shù)組代碼1……代碼N課程1……課程N一一對應新聞1……新聞N每天的新聞總數(shù)不確定,太少浪費空間,太多空間不足存儲一個班學員信息,假定一個班容納20名學員為什么使用集合框架集合類概述集合類的作用:
Java的集合類提供了一些基本數(shù)據結構的支持。例如Vector、Hashtable、Stack等。集合類的使用:Java的集合類包含在java.util包中。importjava.util.*;集合類概述集合類特點一:只容納對象。這一點和數(shù)組不同,數(shù)組可以容納基本數(shù)據類型數(shù)據和對象。如果集合類中想使用基本數(shù)據類型,又想利用集合類的靈活性,可以把基本數(shù)據類型數(shù)據封裝成該數(shù)據類型的對象,然后放入集合中處理。集合類概述集合類特點二:集合類容納的對象都是Object類的實例,一旦把一個對象置入集合類中,它的類信息將丟失,這樣設計的目的是為了集合類的通用性。因為Object類是所有類的祖先,所以可以在這些集合中存放任何類的對象而不受限制,但是切記在使用集合成員之前必須對它重新造型。什么是集合框架的概念集合框架:是為表示和操作集合而規(guī)定的一種統(tǒng)一的、標準的體系結構。任何集合框架都包含三大塊內容:對外的接口、接口的實現(xiàn)和對集合運算的算法。接口:即表示集合的抽象數(shù)據類型。接口提供了讓我們對集合中所表示的內容進行單獨操作的可能。實現(xiàn):也就是集合框架中接口的具體實現(xiàn)。實際它們就是那些可復用的數(shù)據結構。算法:在一個實現(xiàn)了某個集合框架中的接口的對象上,完成某種有用的計算的方法,例如查找、排序等。集合框架對編程有什么好處呢?提高程序設計效率。提高程序速度和質量。集合框架通過提供對有用的數(shù)據結構和算法的高性能和高質量的實現(xiàn)使你的程序速度和質量得到提高。集合框架鼓勵軟件的復用。對于遵照標準集合框架接口的新的數(shù)據結構是可復用的。1接口CollectionListMap2具體類ArrayListLinkedListHashMap3算法Java集合框架為我們提供了一套性能優(yōu)良、使用方便的接口和類,它們位于java.util包中我們不必再重新發(fā)明輪子,只需學會如何使用它們,就可處理實際應用中問題Collections提供了對集合進行排序、遍歷等多種算法實現(xiàn)Java集合框架包含的內容SetTreeSetHashSetTreeMapJava集合框架包含的內容Collection接口存儲一組不唯一,無序的對象List接口存儲一組不唯一,有序(插入順序)的對象Set接口存儲一組唯一,無序的對象Map接口存儲一組鍵值對象,提供key到value的映射
CollectionListMapSetList接口的實現(xiàn)類ArrayList實現(xiàn)了長度可變的數(shù)組,在內存中分配連續(xù)的空間。遍歷元素和隨機訪問元素的效率比較高LinkedList采用鏈表存儲方式。插入、刪除元素時效率比較高ListArrayListLinkedListListList的明顯特征是它的元素都有一個確定的順序。實現(xiàn)它的類有ArrayList和LinkedList。ArrayList內存中是順序存儲的。LinkedList內存中是以鏈表方式存儲的。2114List(列表)0123ArrayList集合類存儲多條狗狗信息,獲取狗狗總數(shù),逐條打印出各條狗狗信息通過List接口的實現(xiàn)類ArrayList實現(xiàn)該需求元素個數(shù)不確定要求獲得元素的實際個數(shù)按照存儲順序獲取并打印元素信息ArrayList集合類publicclassTest1{ publicstaticvoidmain(String[]args){ DogououDog=newDog("歐歐","雪娜瑞"); DogyayaDog=newDog("亞亞","拉布拉多"); DogmeimeiDog=newDog("美美","雪娜瑞"); DogfeifeiDog=newDog("菲菲","拉布拉多");
Listdogs=newArrayList();
dogs.add(ououDog); dogs.add(yayaDog); dogs.add(meimeiDog);
dogs.add(2,feifeiDog);//添加feifeiDog到指定位置
System.out.println("共計有"+dogs.size()+"條狗狗。");
System.out.println("分別是:"); for(inti=0;i<dogs.size();i++){ Dogdog=(Dog)dogs.get(i); System.out.println(dog.getName()+"\t"+dog.getStrain()); } }}創(chuàng)建ArrayList對象并把四個狗狗對象放入其中輸出狗狗的數(shù)量獲取第i個元素
ArrayList舉例importjava.util.*;publicclassArrayListDemo{publicstaticvoidmain(String[]argv){
ArrayListal=newArrayList();//AddlotsofelementstotheArrayList...
al.add(newInteger(11));
al.add(newInteger(12));
al.add(newInteger(13));
al.add(new
String("hello"));//Firstprintthemoutusingaforloop.
System.out.println("Retrievingbyindex:");for(inti=0;i<al.size();i++){
System.out.println("Element"+i+"="+al.get(i));}}}LinkedList類舉例:importjava.util.*;publicclassLinkedListDemo{publicstaticvoidmain(String[]argv){
LinkedListl=newLinkedList();
l.add(newObject());
l.add("Hello");
l.add("zhangsan");
ListIterator
li=l.listIterator(0);while(li.hasNext())
System.out.println(li.next());if(l.indexOf("Hello")<0)
System.err.println("Lookupdoesnotwork");else
System.err.println("Lookupworks");}}補充練習一功能描述:使用ArrayList類保存飯店信息,創(chuàng)建三個飯店的對象保存到ArrayList中,然后遍歷集合輸出顯示,當一個飯店從ArrayList中刪除后,重新輸出剩下的飯店集合,效果如下圖所示補充案例二創(chuàng)建一個類Cat包含屬性name,在構造方法中進行初始化添加一個方法show(),用以打印name屬性的值創(chuàng)建一個類CatTest,添加main方法,實現(xiàn)創(chuàng)建一個ArrayList,向其中添加幾個Cat對象遍歷該集合,并且對每個Cat對象調用show()方法ArrayList集合類擴充以下幾部分功能刪除指定位置的狗狗,如第一個狗狗刪除指定的狗狗,如刪除feifeiDog對象判斷集合中是否包含指定狗狗List接口提供相應方法remove()、contains(),直接使用即可ArrayList集合類publicclassTest2{ publicstaticvoidmain(String[]args){ //1、創(chuàng)建多個狗狗對象 … //2、創(chuàng)建ArrayList集合對象并把多個狗狗對象放入其中 …
System.out.println("刪除之前共計有"+dogs.size()+"條狗狗。");
dogs.remove(0);
dogs.remove(feifeiDog);
System.out.println("\n刪除之后還有"+dogs.size()+"條狗狗。"); …
if(dogs.contains(meimeiDog)) System.out.println("\n集合中包含美美的信息"); else System.out.println("\n集合中不包含美美的信息"); }}刪除第一個狗狗和feifeiDog判斷是否包含指定狗狗ArrayList集合類List接口常用方法
方法名說明booleanadd(Objecto)在列表的末尾順序添加元素,起始索引位置從0開始voidadd(intindex,Objecto)在指定的索引位置添加元素。索引位置必須介于0和列表中元素個數(shù)之間intsize()返回列表中的元素個數(shù)Objectget(intindex)返回指定索引位置處的元素。取出的元素是Object類型,使用前需要進行強制類型轉換booleancontains(Objecto)判斷列表中是否存在指定元素booleanremove(Objecto)從列表中刪除元素Object remove(intindex)從列表中刪除指定位置元素,起始索引位置從0開始LinkedList集合類在集合任何位置(頭部、中間、尾部)添加、獲取、刪除狗狗對象插入、刪除操作頻繁時,可使用LinkedList來提高效率LinkedList還額外提供對頭部和尾部元素進行添加和刪除操作的方法LinkedList集合類3-2publicclassTest3{ publicstaticvoidmain(String[]args){ …//創(chuàng)建多個狗狗對象
LinkedListdogs=newLinkedList(); dogs.add(ououDog); dogs.add(yayaDog);
dogs.addLast(meimeiDog); dogs.addFirst(feifeiDog);
DogdogFirst=(Dog)dogs.getFirst(); System.out.println("第一條狗狗昵稱是"+dogFirst.getName());
DogdogLast=(Dog)dogs.getLast(); System.out.println("最后一條狗狗昵稱是"+dogLast.getName());
dogs.removeFirst(); dogs.removeLast();
…
}}創(chuàng)建LinkedList集合對象并把多個狗狗對象放入其中獲取第一條狗狗信息獲取最后一條狗狗信息刪除第一個狗狗和最后一個狗狗 LinkedList集合類LinkedList的特殊方法方法名說明void addFirst(Objecto)在列表的首部添加元素void addLast(Objecto)在列表的末尾添加元素Object getFirst()返回列表中的第一個元素Object getLast()返回列表中的最后一個元素Object removeFirst()刪除并返回列表中的第一個元素Object removeLast()刪除并返回列表中的最后一個元素補充練習三功能描述:使用LinkedList保存人員信息,并調用相關方法實現(xiàn)輸出顯示。效果如圖所示:補充案例四創(chuàng)建一個類Stack,代表堆棧(其特點為:后進先出),添加方法add(Objectobj)、以及delete(),添加main方法進行驗證,要求:使用LinkedList實現(xiàn)堆棧在向LinkedList中添加時,使用addLast()方法在從LinkedList中取出時,使用removeLast()方法集合框架中的接口集合框架中的接口Collection:集合層次中的根接口,JDK沒有提供這個接口直接的實現(xiàn)類。Set:不能包含重復的元素。SortedSet是一個按照升序排列元素的Set。List:是一個有序的集合,可以包含重復的元素。提供了按索引訪問的方式。Map:包含了key-value對。Map不能包含重復的key。SortedMap是一個按照升序排列key的Map。CollectionSetSet中的元素必須唯一。添加到Set中的元素必須定義equals方法,以提供算法來判斷欲添加進來的對象是否與已經存在的某對象相等,從而建立對象的唯一性。實現(xiàn)Set接口的類有HashSet,TreeSet。4627351Set集SetSet舉例importjava.util.*;publicclassSetDemo{publicstaticvoidmain(String[]argv){
HashSeth=newHashSet();//也可以Seth=newHashSet()
h.add("One");
h.add("Two");
h.add("One");//DUPLICATE
h.add("Three");
Iteratorit=h.iterator();while(it.hasNext()){
System.out.println(it.next());}}}Map接口建立國家英文簡稱和中文全名間的鍵值映射,并通過key對value進行操作,應該如何實現(xiàn)數(shù)據的存儲和操作呢?Map接口專門處理鍵值映射數(shù)據的存儲,可以根據鍵實現(xiàn)對值的操作最常用的實現(xiàn)類是HashMapMap接口3-2publicclassTest4{ publicstaticvoidmain(String[]args){
Mapcountries=newHashMap();
countries.put("CN","中華人民共和國"); countries.put("RU","俄羅斯聯(lián)邦"); countries.put("FR","法蘭西共和國"); countries.put("US","美利堅合眾國");
Stringcountry=(String)countries.get("CN"); System.out.println("CN對應的國家是:"+country);
System.out.println("Map中共有"+countries.size()+"組數(shù)據");
countries.remove("FR"); System.out.println("Map中包含F(xiàn)R的key嗎?"+
countries.containsKey("FR"));
System.out.println(countries.keySet()); System.out.println(countries.values()); System.out.println(countries); }}使用HashMap存儲多組鍵值對獲取Map元素個數(shù)刪除指定元素,判斷是否包含指定元素顯示鍵集、值集和鍵值對集獲取指定元素的值Map接口Map接口常用方法方法名說明Objectput(Objectkey,Objectval)以“鍵-值對”的方式進行存儲Objectget(Objectkey)根據鍵返回相關聯(lián)的值,如果不存在指定的鍵,返回nullObjectremove(Objectkey)刪除由指定的鍵映射的“鍵-值對”intsize()返回元素個數(shù)SetkeySet()返回鍵的集合Collectionvalues()返回值的集合boolean containsKey(Objectkey)如果存在由指定的鍵映射的“鍵-值對”,返回true集合類對比Vector和ArrayList的異同實現(xiàn)原理相同,功能相同,很多情況下可以互用兩者的主要區(qū)別如下Vector線程安全,ArrayList重速度輕安全,線程非安全長度需增長時,Vector默認增長一倍,ArrayList增長50%Hashtable和HashMap的異同實現(xiàn)原理相同,功能相同,在很多情況下可以互用兩者的主要區(qū)別如下Hashtable繼承Dictionary類,HashMap實現(xiàn)Map接口Hashtable線程安全,HashMap線程非安全Hashtable不允許null值,HashMap允許null值開發(fā)過程中,最好使用ArrayList和HashMap練習——根據寵物昵稱查找寵物需求說明:根據寵物昵稱查找對應寵物,如果找到,顯示寵物信息,否則給出錯誤提示迭代器Iterator如何遍歷List集合呢?方法1:通過for循環(huán)和get()方法配合實現(xiàn)遍歷方法2:通過迭代器Iterator實現(xiàn)遍歷所有集合接口和類都沒有提供相應遍歷方法,而是由Iterator實現(xiàn)集合遍歷Collection接口的iterate()方法返回一個Iterator,然后通過Iterator接口的兩個方法可實現(xiàn)遍歷booleanhasNext():判斷是否存在另一個可訪問的元素Objectnext():返回要訪問的下一個元素迭代器Iterator2-2publicclassTest5{ publicstaticvoidmain(String[]args){ //1、創(chuàng)建多個狗狗對象 DogououDog=newDog("歐歐","雪娜瑞"); … //2、創(chuàng)建ArrayList集合對象并把多個狗狗對象放入其中 Listdogs=newArrayList(); dogs.add(ououDog); …
System.out.println("使用Iterator遍歷,所有狗狗昵稱和品種是:");
Iteratorit=dogs.iterator(); while(it.hasNext()){ Dogdog=(Dog)it.next(); System.out.println(dog.getName()+"\t"+dog.getStrain()); } }}通過迭代器依次輸出所有狗狗的信息練習——迭代List中企鵝信息需求說明:使用ArrayList和LinkedList存儲多個企鵝信息,然后統(tǒng)一使用Iterator進行遍歷泛型集合把任何類型對象通過add(Objectobj)放入List中,認為只是Object類型通過get(intindex)取出List中元素時必須進行強制類型轉換,繁瑣而且容易出現(xiàn)異常使用Map的put(Objectkey,Objectvalue)和get(Objectkey)存取對象時存在同樣問題使用Iterator的next()方法獲取元素時存在同樣問題JDK5.0中通過引入泛型有效的解決了這個問題JDK5.0使用泛型改寫了集合框架中的所有接口和類泛型集合3-2publicclassTest6{ publicstaticvoidmain(String[]args){ //1、創(chuàng)建多個狗狗對象 Dogdog1=newDog("歐歐","雪娜瑞"); … //2、創(chuàng)建ArrayList集合對象并把多個狗狗對象放入其中 List<Dog>dogs=newArrayList<Dog>
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 鐵道專業(yè)課程設計
- 幼兒園大班鏡面課程設計
- 疫情下主題課程設計
- 預應力t型板課程設計
- 輔導機構開設課程設計
- 輔導論壇課程設計
- 軸齒輪檢查儀課程設計
- 高數(shù)課程設計展示
- 幼兒園學期茶藝課程設計
- 課程設計論文選題原因
- 人教部編版七年級語文上冊《閱讀綜合實踐》示范課教學設計
- (正式版)QC∕T 1206.1-2024 電動汽車動力蓄電池熱管理系統(tǒng) 第1部分:通 用要求
- 《煤礦地質工作細則》礦安﹝2024﹞192號
- 平面向量及其應用試題及答案
- 消防控制室值班服務人員培訓方案
- 《貴州旅游介紹》課件2
- 2024年中職單招(護理)專業(yè)綜合知識考試題庫(含答案)
- 無人機應用平臺實施方案
- 挪用公款還款協(xié)議書范本
- 事業(yè)單位工作人員年度考核登記表(醫(yī)生個人總結)
- 盾構隧道施工數(shù)字化與智能化系統(tǒng)集成
評論
0/150
提交評論