詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)
成都創(chuàng)新互聯(lián)公司是專業(yè)的薩爾圖網(wǎng)站建設(shè)公司,薩爾圖接單;提供成都網(wǎng)站建設(shè)、成都網(wǎng)站制作,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行薩爾圖網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
Java集合類可分為三大塊,分別是從Collection接口延伸出的List、Set和以鍵值對(duì)形式作存儲(chǔ)的Map類型集合。
關(guān)于增強(qiáng)for循環(huán),需要注意的是,使用增強(qiáng)for循環(huán)無法訪問數(shù)組下標(biāo)值,對(duì)于集合的遍歷其內(nèi)部采用的也是Iterator的相關(guān)方法。如果只做簡(jiǎn)單遍歷讀取,增強(qiáng)for循環(huán)確實(shí)減輕不少的代碼量。
集合概念:
1.作用:用于存放對(duì)象
2.相當(dāng)于一個(gè)容器,里面包含著一組對(duì)象,其中的每個(gè)對(duì)象作為集合的一個(gè)元素出現(xiàn)
3.java的容器有集合類和數(shù)組,不同之處是
區(qū)別及其常用實(shí)現(xiàn)類
List接口:
列表有序 元素可重復(fù)
實(shí)現(xiàn)類:ArrayList:動(dòng)態(tài)數(shù)組列表
LinkedList:雙向鏈表
Set接口:
集無序,元素不可重復(fù)
實(shí)現(xiàn)類:HashSet:散列集
TreeSet:樹集 內(nèi)部排序
Map接口:
以鍵值對(duì)的方式存儲(chǔ)數(shù)據(jù) 數(shù)據(jù)-鍵不允許重復(fù)
實(shí)現(xiàn)類:HashSet:散列集
TreeSet:樹集 內(nèi)部排序
JDK1.0出現(xiàn)的集合類都是線程安全的,但效率低
JDK1.2出現(xiàn)的集合類都不是線程安全的,但效率高
代碼示例如下:
import java.util.ArrayList; import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Set; public class ListAndSet{ public static void main(String[] args) { setTest(); listTest(); } // 遍歷Set集合 private static void setTest() { Set<string> set = new HashSet<string>(); set.add("A"); set.add("B"); set.add("C"); set.add("D"); set.add("E"); //set集合遍歷方法1:使用iterator Iterator<string> it = set.iterator(); while (it.hasNext()) { String value = it.next(); System.out.println(value); } //set集合遍歷方法2:使用增強(qiáng)for循環(huán)。 for(String s: set){ System.out.println(s); } } // 遍歷list集合 private static void listTest() { List<string> list = new ArrayList<string>(); list.add("111"); list.add("222"); list.add("333"); list.add("444"); list.add("555"); // 遍歷方式1:使用iterator Iterator<string> it = list.iterator(); while (it.hasNext()) { String value = it.next(); System.out.println(value); } // 遍歷方法2:使用傳統(tǒng)for循環(huán)進(jìn)行遍歷。 for (int i = 0, size = list.size(); i < size; i++) { String value = list.get(i); System.out.println(value); } // 遍歷方法3:使用增強(qiáng)for循環(huán)進(jìn)行遍歷。 for (String value : list) { System.out.println(value); } } } //關(guān)于Map類型集合的遍歷,keySet()與entrySet()方法 //增強(qiáng)For循環(huán) public class Map{ public static void main(String[] args) { // 創(chuàng)建一個(gè)HashMap對(duì)象,并加入了一些鍵值對(duì)。 Map<string, string=""> maps = new HashMap<string, string="">(); maps.put("111", "111"); maps.put("222", "222"); maps.put("333", "333"); maps.put("444", "444"); maps.put("555", "555"); // 傳統(tǒng)的遍歷map集合的方法1; keySet() //traditionalMethod1(maps); // 傳統(tǒng)的遍歷map集合的方法2; entrySet() //traditionalMethod2(maps); // 使用增強(qiáng)For循環(huán)來遍歷map集合方法1; keySet() //strongForMethod1(maps); // 使用增強(qiáng)For循環(huán)來遍歷map集合方法2; entrySet() strongForMethod2(maps); } private static void strongForMethod2(Map<string, string=""> maps) { Set<entry<string, string="">> set = maps.entrySet(); for (Entry<string, string=""> entry : set) { String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } private static void strongForMethod1(Map<string, string=""> maps) { Set<string> set = maps.keySet(); for (String s : set) { String key = s; String value = maps.get(s); System.out.println(key + " : " + value); } } // 使用entrySet()方法,獲取maps集合中的每一個(gè)鍵值對(duì), private static void traditionalMethod2(Map<string, string=""> maps) { Set<map.entry<string, string="">> sets = maps.entrySet(); // 取得迭代器遍歷出對(duì)應(yīng)的值。 Iterator<entry<string, string="">> it = sets.iterator(); while (it.hasNext()) { Map.Entry<string, string=""> entry = (Entry<string, string="">) it.next(); String key = entry.getKey(); String value = entry.getValue(); System.out.println(key + " : " + value); } } // 使用keySet()方法,獲取maps集合中的所有鍵,遍歷鍵取得所對(duì)應(yīng)的值。 private static void traditionalMethod1(Map<string, string=""> maps) { Set<string> sets = maps.keySet(); // 取得迭代器遍歷出對(duì)應(yīng)的值。 Iterator<string> it = sets.iterator(); while (it.hasNext()) { String key = it.next(); String value = maps.get(key); System.out.println(key + " : " + value); } } }
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
文章標(biāo)題:詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)
網(wǎng)站網(wǎng)址:http://aaarwkj.com/article28/psocjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、商城網(wǎng)站、企業(yè)建站、Google、品牌網(wǎng)站制作、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)