新聞中心
本篇內(nèi)容主要講解“Java HashMap簡便的排序方法有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java HashMap簡便的排序方法有哪些”吧!
HashMap的儲存是沒有順序的,而是按照key的HashCode實現(xiàn).
key=手機品牌,value=價格,這里以這個例子實現(xiàn)按名稱排序和按價格排序.
Map phone=new HashMap(); phone.put("Apple",8899); phone.put("SAMSUNG",7000); phone.put("Meizu",2698); phone.put("Xiaomi",1800); System.out.println(phone);
直接輸出HashMap得到的是一個無序Map(不是Arraylist那種順序型儲存)
1. 按key排序
對名稱進行排序,首先要得到HashMap中鍵的集合(keySet),并轉(zhuǎn)換為數(shù)組,這樣才能用Arrays.sort()進行排序
Set set=phone.keySet(); Object[] arr=set.toArray(); Arrays.sort(arr); for(Object key:arr){ System.out.println(key); }
得到排序好的鍵值
最后利用HashMap.get(key)得到鍵對應的值即可
for(Object key:arr){ System.out.println(key+": "+phone.get(key)); }
得到的打印的結果
2.按value排序
對價格進行排序,首先需要得到HashMap中的包含映射關系的視圖(entrySet),如圖:
將entrySet轉(zhuǎn)換為List,然后重寫比較器比較即可.這里可以使用List.sort(comparator),也可以使用Collections.sort(list,comparator)
轉(zhuǎn)換為list
List
使用list.sort()排序
list.sort(new Comparator
使用Collections.sort()排序
Collections.sort(list, new Comparator
兩種方式結果輸出
//for循環(huán) for (int i = 0; i < list.size(); i++) { System.out.println(list.get(i).getKey() + ": " + list.get(i).getValue()); } //for-each循環(huán) for (Map.Entry
遍歷打印輸出
//for for (int i = 0; i < list.size(); i++) { System.out.println(list.get(i).getKey() + ": " +list.get(i).getValue()); } System.out.println(); //for-each for (Map.Entry
到此,相信大家對“Java HashMap簡便的排序方法有哪些”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!
標題名稱:JavaHashMap簡便的排序方法有哪些-創(chuàng)新互聯(lián)
文章起源:http://www.ef60e0e.cn/article/dohpes.html