一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - Java中Map的排序問題詳解

Java中Map的排序問題詳解

2020-03-25 13:39hebedich JAVA教程

本文給大家分享的是java中的map的按值排序和按鍵排序問題,并通過具體的示例,希望對大家能有所幫助。

Map的種類

在Java中,Map的主要作用是存儲鍵值對。由于是根據(jù)鍵得到值,所以不允許鍵重復(fù)。它主要有如下幾個類別:

HashMap:

最常用的Map,它根據(jù)鍵的HashCode值存儲數(shù)據(jù),根據(jù)鍵可以直接獲取它的值,具有很快的訪問速度,遍歷時,取得數(shù)據(jù)的順序是完全隨機的。HashMap最多只允許一條記錄的鍵為Null;允許多條記錄的值為Null;HashMap不支持線程的同步,即任一時刻可以有多個線程同時寫HashMap;可能會導(dǎo)致數(shù)據(jù)的不一致。如果需要同步,可以用Collections的synchronizedMap方法使HashMap具有同步的能力,或者使用ConcurrentHashMap。Hashtable與HashMap類似,它繼承自Dictionary類,不同的是:它不允許記錄的鍵或者值為空;它支持線程的同步,即任一時刻只有一個線程能寫Hashtable,因此也導(dǎo)致了 Hashtable在寫入時會比較慢。

LinkedHashMap

保存了記錄的插入順序,在用Iterator遍歷LinkedHashMap時,先得到的記錄肯定是先插入的.也可以在構(gòu)造時用帶參數(shù),按照應(yīng)用次數(shù)排序。在遍歷的時候會比HashMap慢,不過有種情況例外,當(dāng)HashMap容量很大,實際數(shù)據(jù)較少時,遍歷起來可能會比LinkedHashMap慢,因為LinkedHashMap的遍歷速度只和實際數(shù)據(jù)有關(guān),和容量無關(guān),而HashMap的遍歷速度和他的容量有關(guān)。

TreeMap

實現(xiàn)SortMap接口,能夠把它保存的記錄根據(jù)鍵排序,默認(rèn)是按鍵值的升序排序,也可以指定排序的比較器,當(dāng)用Iterator 遍歷TreeMap時,得到的記錄是排過序的。

按鍵排序

從上面Map的種類介紹我們可以看出,TreeMap是自帶按鍵排序的功能的,只需要在創(chuàng)建的時候同時實現(xiàn)一個Compare的接口就可以了,例子如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
private static void sort_by_key(){
    Map<Integer, Integer> treeMap = new TreeMap<>(new Comparator<Integer>() {
      @Override
      public int compare(Integer o1, Integer o2) {
        return o2-o1; //倒序.這里說明一下,如果返回負(fù)值,則o1先輸出,反之則o2
      }
    });
    
    //填充數(shù)據(jù)
    for(int i = 0; i < 100;i++){
      int key = (int)(10000*Math.random());
      int value = (int)(10000*Math.random());
      treeMap.put(key, value);
    }
    outMap(treeMap);
  }
 
public static void outMap(Map<Integer, Integer> map){
    for(Integer integer:map.keySet()){
      System.out.println("key="+integer+"  value="+map.get(integer));
    }
}
/* 結(jié)果如下:
key=9977  value=80
key=9684  value=7108
key=9422  value=1706
key=9264  value=1210
key=9248  value=4758
key=9024  value=7048
key=8892  value=3124
key=8879  value=6414
key=8814  value=8171
key=8728  value=1538
key=8513  value=4956
key=8462  value=5617
key=8355  value=8912
*/

從上面可以看出,按鍵排序是不難的,而安置排序就比較麻煩一些,需要將Map轉(zhuǎn)一下。

按值排序

由于Java中Map并沒有此功能,所以我們需要自己實現(xiàn)。思路如下:

Java中List是可以使用compare接口的。
Map實際上就是Entry<>的集合
那么使用List<Entry<>>就可以實現(xiàn)排序
將排好序的元素再插入到LinkedMap中

代碼實現(xiàn)如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
private static Map<Integer, Integer> sortMap(Map<Integer, Integer> linkedMap) {
    
    List<Map.Entry<Integer, Integer>> cache = new ArrayList<>(linkedMap.entrySet());
 
    //重寫比較函數(shù)
    Collections.sort(cache,new Comparator<Map.Entry<Integer, Integer>>() {
      @Override
      public int compare(Entry<Integer, Integer> o1, Entry<Integer, Integer> o2) {
        //若返回值小于0,則o1在o2前面
        return o2.getValue()-o1.getValue();
      }
    });
 
    Map<Integer, Integer> resultMap = new LinkedHashMap<>();
    //將結(jié)果插入LinkedMap然后返回
    for(int i = 0; i < cache.size();i++){
      resultMap.put(cache.get(i).getKey(), cache.get(i).getValue());
    }
    return resultMap;
  }
/*結(jié)果:
7965  9966
1067  9963
1720  9833
3257  9738
3934  9578
777  9348
1924  9315
3472  9270
3649  9114
5892  9078
*/

這樣,按值排序和按鍵排序就都可以實現(xiàn)了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日产精品卡一卡2卡三卡乱码工厂 | 精品国产中文字幕在线视频 | 青青在线视频免费 | 翁息肉小说老扒 | 久久er国产精品免费观看2 | 欧美在线视频免费播放 | 3d蒂法受辱在线播放 | 幻女free性俄罗斯第一次摘花 | 亚洲一区二区三区福利在线 | 亚洲国产AV无码综合在线 | 交换年轻夫妇HD中文字幕 | 亚洲成色 | 韩国成人毛片aaa黄 含羞草国产亚洲精品岁国产精品 | 含羞草传媒网站免费进入欢迎 | 国产午夜永久福利视频在线观看 | 外女思春台湾三级 | 欧美精品一线二线大片 | 日日操综合 | 国产精品二区高清在线 | 性福演算法 | 婷婷激情综合五月天 | 精品午夜久久网成年网 | 国产精品国产色综合色 | 免费观看毛片视频 | 免费观看视频在线播放 | 大陆日韩欧美 | 色老太bbbbb| 成人免费在线视频观看 | 把女的下面扒开添视频 | 免费黄色片在线观看 | 成人3p视频免费 | 欧美精品国产一区二区 | 日韩精品一区二区三区中文在线 | 5555kkkk香蕉在线观看 | 亚洲天堂成人在线观看 | 国产原创一区二区 | 国内精品国语自产拍在线观看55 | 色噜噜狠狠色综合 | 国产免费又粗又猛又爽视频国产 | 禁忌第一季第3季 | 精品国产免费久久久久久婷婷 |