Java Map 按key排序和按Value排序


title: Java Map 按key排序和按Value排序
date: 2016/8/31 15:24:13
tags: Java
categories: Java


做推薦系統(tǒng)項目時,對標簽評分需要對標簽評分map進行排序.

理論準備

  • Map是鍵值對的集合接口,它的實現(xiàn)類主要包括:HashMap,TreeMap,Hashtable以及LinkedHashMap等甘有。

  • TreeMap:基于紅黑樹(Red-Black tree)的 NavigableMap 實現(xiàn)塘淑,該映射根據(jù)其鍵的自然順序進行排序箱歧,或者根據(jù)創(chuàng)建映射時提供的 Comparator 進行排序狰晚,具體取決于使用的構(gòu)造方法盏筐。
    HashMap的值是沒有順序的收厨,它是按照key的HashCode來實現(xiàn)的晋柱,對于這個無序的HashMap我們要怎么來實現(xiàn)排序呢?參照TreeMap的value排序诵叁。

  • Map.Entry返回Collections視圖雁竞。

key排序

TreeMap默認是升序的,如果我們需要改變排序方式拧额,則需要使用比較器:Comparator碑诉。Comparator可以對集合對象或者數(shù)組進行排序的比較器接口彪腔,實現(xiàn)該接口的public compare(T o1,To2)方法即可實現(xiàn)排序,如下:

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:aaaaa
c:bbbbb
b:ccccc
a:ddddd

value排序

上面例子是對根據(jù)TreeMap的key值來進行排序的进栽,但是有時我們需要根據(jù)TreeMap的value來進行排序漫仆。對value排序我們就需要借助于Collections的sort(List<T> list, Comparator<? super T> c)方法,該方法根據(jù)指定比較器產(chǎn)生的順序?qū)χ付斜磉M行排序泪幌。但是有一個前提條件盲厌,那就是所有的元素都必須能夠根據(jù)所提供的比較器來進行比較,如下:

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()轉(zhuǎn)換成list
        List<Map.Entry<String,String>> list = new ArrayList<Map.Entry<String,String>>(map.entrySet());
        //然后通過比較器來實現(xiàn)排序
        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()); 
          } 
    }
}

運行結(jié)果如下:

d:aaaaa
c:bbbbb
b:ccccc
a:ddddd

參考:http://blog.csdn.net/xiaoyu714543065/article/details/38519817

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末祸泪,一起剝皮案震驚了整個濱河市吗浩,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌没隘,老刑警劉巖懂扼,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異右蒲,居然都是意外死亡阀湿,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門瑰妄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來陷嘴,“玉大人,你說我怎么就攤上這事间坐≡职ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵竹宋,是天一觀的道長劳澄。 經(jīng)常有香客問我,道長蜈七,這世上最難降的妖魔是什么秒拔? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮飒硅,結(jié)果婚禮上砂缩,老公的妹妹穿的比我還像新娘。我一直安慰自己狡相,他們只是感情好梯轻,可當(dāng)我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著尽棕,像睡著了一般喳挑。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天伊诵,我揣著相機與錄音单绑,去河邊找鬼。 笑死曹宴,一個胖子當(dāng)著我的面吹牛搂橙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播笛坦,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼区转,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了版扩?” 一聲冷哼從身側(cè)響起废离,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎礁芦,沒想到半個月后蜻韭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡柿扣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年肖方,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片未状。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡俯画,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出娩践,到底是詐尸還是另有隱情活翩,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布翻伺,位于F島的核電站,受9級特大地震影響沮焕,放射性物質(zhì)發(fā)生泄漏吨岭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一峦树、第九天 我趴在偏房一處隱蔽的房頂上張望辣辫。 院中可真熱鬧,春花似錦魁巩、人聲如沸急灭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽葬馋。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間畴嘶,已是汗流浹背蛋逾。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留窗悯,地道東北人区匣。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像蒋院,于是被迫代替她去往敵國和親亏钩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 一、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,261評論 0 16
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法切端,類相關(guān)的語法彻坛,內(nèi)部類的語法,繼承相關(guān)的語法踏枣,異常的語法昌屉,線程的語...
    子非魚_t_閱讀 31,631評論 18 399
  • 前面已經(jīng)介紹完了Collection接口下的集合實現(xiàn)類,今天我們來介紹Map接口下的兩個重要的集合實現(xiàn)類HashM...
    Ruheng閱讀 10,456評論 2 38
  • 從三月份找實習(xí)到現(xiàn)在茵瀑,面了一些公司间驮,掛了不少,但最終還是拿到小米马昨、百度竞帽、阿里、京東鸿捧、新浪屹篓、CVTE、樂視家的研發(fā)崗...
    時芥藍閱讀 42,246評論 11 349
  • 本篇文章帶你從Java源碼深入解析關(guān)于Java容器的概念谍肤。 參考文獻: Java容器相關(guān)知識全面總結(jié) Java官方...
    Tsy遠閱讀 19,776評論 13 142