Java Map 按key排序和按Value排序的實現方法_java

來源:互聯網
上載者:User

一、理論準備

Map是索引值對的集合介面,它的實作類別主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等。

TreeMap:基於紅/黑樹狀結構(Red-Black tree)的 NavigableMap 實現,該映射根據其鍵的自然順序進行排序,或者根據建立映射時提供的 Comparator 進行排序,具體取決於使用的構造方法。

HashMap的值是沒有順序的,它是按照key的HashCode來實現的,對於這個無序的HashMap我們要怎麼來實現排序呢?參照TreeMap的value排序。

Map.Entry返回Collections視圖。

二、key排序

TreeMap預設是升序的,如果我們需要改變排序方式,則需要使用比較子:Comparator。Comparator可以對集合對象或者數組進行排序的比較子介面,實現該介面的public compare(T o1,To2)方法即可實現排序,如下:

import java.util.Comparator;import java.util.Iterator;import java.util.Map;import java.util.Set;import java.util.TreeMap;public class TreeMapTest {  public static void main(String[] args) {    Map<String, String> map = new TreeMap<String, String>(        new Comparator<String>() {          public int compare(String obj1, String obj2) {            // 降序排序            return obj2.compareTo(obj1);          }        });    map.put("b", "ccccc");    map.put("d", "aaaaa");    map.put("c", "bbbbb");    map.put("a", "ddddd");        Set<String> keySet = map.keySet();    Iterator<String> iter = keySet.iterator();    while (iter.hasNext()) {      String key = iter.next();      System.out.println(key + ":" + map.get(key));    }  }}

運行結果如下:

d:aaaaac:bbbbbb:ccccca:ddddd

三、value排序

上面例子是對根據TreeMap的key值來進行排序的,但是有時我們需要根據TreeMap的value來進行排序。對value排序我們就需要藉助於Collections的sort(List<T> list, Comparator<? super T> c)方法,該方法根據指定比較子產生的順序對指定列表進行排序。但是有一個前提條件,那就是所有的元素都必須能夠根據所提供的比較子來進行比較,如下:

import java.util.ArrayList;import java.util.Collections;import java.util.Comparator;import java.util.List;import java.util.Map;import java.util.Map.Entry;import java.util.TreeMap;public class TreeMapTest {  public static void main(String[] args) {    Map<String, String> map = new TreeMap<String, String>();    map.put("a", "ddddd");    map.put("c", "bbbbb");    map.put("d", "aaaaa");    map.put("b", "ccccc");        //這裡將map.entrySet()轉換成list    List<Map.Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());    //然後通過比較子來實現排序    Collections.sort(list,new Comparator<Map.Entry<String,String>>() {      //升序排序      public int compare(Entry<String, String> o1,          Entry<String, String> o2) {        return o1.getValue().compareTo(o2.getValue());      }          });        for(Map.Entry<String,String> mapping:list){         System.out.println(mapping.getKey()+":"+mapping.getValue());      }   }}

 運行結果如下:

d:aaaaac:bbbbbb:ccccca:ddddd

以上這篇Java Map 按key排序和按Value排序的實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.