java技術(shù)從入門到精通孫鑫學(xué)習(xí)筆記Lesson6_集合類_第1頁
java技術(shù)從入門到精通孫鑫學(xué)習(xí)筆記Lesson6_集合類_第2頁
java技術(shù)從入門到精通孫鑫學(xué)習(xí)筆記Lesson6_集合類_第3頁
java技術(shù)從入門到精通孫鑫學(xué)習(xí)筆記Lesson6_集合類_第4頁
java技術(shù)從入門到精通孫鑫學(xué)習(xí)筆記Lesson6_集合類_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、集合框架中的listsetmapsortedmapsortedsetcollectioncollection接口所謂框架就是一個類庫的集合。集合框架就是一個用來表示和操作集合的統(tǒng)一的架構(gòu),包含了實現(xiàn)集合的接口與類。l collection:集合層次中的根接口,jdk沒有提供這個接口直接的實現(xiàn)類。l set:不能包含重復(fù)的元素。sortedset是一個按照升序排列元素的set。l list:是一個有序的集合,可以包含重復(fù)的元素。提供了按索引訪問的方式。l map:包含了key-value對。map不能包含重復(fù)的key。sortedmap是一個按照升序排列key的map。框架中的實現(xiàn)類sorted

2、setsethashsetlinkedhashsettreesetmapsortedmaplisthashmaptreemaplinkedlistarraylist注:實線表示繼承,虛線表示實現(xiàn)arraylistl arraylist:我們可以將其看作是能夠自動增長容量的數(shù)組。l 利用arraylist的toarray()返回一個數(shù)組。l arrays.aslist()返回一個列表。l 迭代器(iterator)給我們提供了一種通用的方式來訪問集合中的元素。import java.util.*;class arraylisttestpublic static void main(string

3、args)arraylist al=new arraylist();al.add("abort");al.add("bole");al.add("come");for(int i=0;i<al.size();i+)system.out.println(al.get(i);運行結(jié)果為: abort bole comeimport java.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.add

4、("abort");al.add("bole");al.add("come");/*for(int i=0;i<al.size();i+)system.out.println(al.get(i);*/system.out.println(al);運行結(jié)果為: abort bole comeimport java.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.add(new point(1,

5、1);al.add(new point(2,2);al.add(new point(3,3);/*al.add("abort");al.add("bole");al.add("come");*/*for(int i=0;i<al.size();i+)system.out.println(al.get(i);*/system.out.println(al);class pointint x,y;point(int x,int y)this.x=x;this.y=y;public string tostring()return &q

6、uot;x="+x+","+"y="+y;運行結(jié)果為: x=1,y=1, x=2,y=2, x=3,y=3import java.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.add(new point(1,1);al.add(new point(2,2);al.add(new point(3,3);object objs=al.toarray();for(int i=0;i<objs.length

7、;i+)system.out.println(objsi);class pointint x,y;point(int x,int y)this.x=x;this.y=y;public string tostring()return "x="+x+","+"y="+y;運行結(jié)果為: x=1,y=1 x=2,y=2 x=3,y=3import java.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.

8、add(new point(1,1);al.add(new point(2,2);al.add(new point(3,3);list l=arrays.aslist(objs); /* l.add(“tome”); 這條語句非法,因為aslist()返回的是一個固定長度的列表,不能再增加元素了。*/system.out.println(l);class pointint x,y;point(int x,int y)this.x=x;this.y=y;public string tostring()return "x="+x+","+"y=&q

9、uot;+y;運行結(jié)果為: x=1,y=1, x=2,y=2, x=3,y=3import java.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.add(new point(1,1);al.add(new point(2,2);al.add(new point(3,3);/*al.add("abort");al.add("bole");al.add("come");*/*for(int i=0

10、;i<al.size();i+)system.out.println(al.get(i);*/object objs=al.toarray();/*for(int i=0;i<objs.length;i+)system.out.println(objsi);*/list l=arrays.aslist(objs);/system.out.println(l);iterator it=al.iterator();while(it.hasnext()system.out.println(it.next();運行結(jié)果為: x=1,y=1 x=2,y=2 x=3,y=3import jav

11、a.util.*;class arraylisttestpublic static void main(string args)arraylist al=new arraylist();al.add(new point(1,1);al.add(new point(2,2);al.add(new point(3,3);object objs=al.toarray();list l=arrays.aslist(objs);iterator it=al.iterator();it.next();it.remove();while(it.hasnext()system.out.println(it.n

12、ext();class pointint x,y;point(int x,int y)this.x=x;this.y=y;public string tostring()return "x="+x+","+"y="+y;運行結(jié)果為: x=2,y=2 x=3,y=3import java.util.*;class arraylisttest /迭代器的好處public static void printelements(collection c)iterator it=c.iterator();while(it.hasnext()sys

13、tem.out.println(it.next(); public static void main(string args)arraylist al=new arraylist();al.add(new point(1,1);al.add(new point(2,2);al.add(new point(3,3);printelements(al);class pointint x,y;point(int x,int y)this.x=x;this.y=y;public string tostring()return "x="+x+","+"y

14、="+y;運行結(jié)果為: x=1,y=1 x=2,y=2 x=3,y=3collections類l 排序:collections.sort()(1) 自然排序(natural ordering);(2) 實現(xiàn)比較器(comparator)接口。l 取最大和最小的元素:collections.max()、collections.min()。l 在已排序的list中搜索指定的元素:collections.binarysearch()。import java.util.*;class collectionstestpublic static void printelements(collec

15、tion c)iterator it=c.iterator();while(it.hasnext()system.out.println(it.next();public static void main(string args)student s1=new student(2,"zhangsan");student s2=new student(1,"lisi");student s3=new student(3,"wangwu");arraylist al=new arraylist();al.add(s1);al.add(s2);al.add(s3);collections.sort(al);printelements(al);class student implements comparableint num;strin

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論