用java的Comparator给JsonArray、TreeMap、HashMap排序

  • JsonArray排序:
public List<JSONObject> getSortJsonList(JSONArray jsonArray){
        List<JSONObject> jsonObjectList=new ArrayList<JSONObject>();
        for(int i=0;i<jsonArray.size();i++){
            JSONObject temp= jsonArray.getJSONObject(i);
            jsonObjectList.add(temp);
        }
        //Lambda表达式 Java编译器可以自动推导出参数类型,所以不用再写一次类型。  下面写法可以用lambda表达式代替
        //Collections.sort(jsonObjectList, (a, b) -> String.valueOf(a.get("day_id")).compareTo(String.valueOf(b.get("day_id"))));//升序
        //老版本的写法
        Collections.sort(jsonObjectList, new Comparator<JSONObject>(){
            @Override
            public int compare(JSONObject o1, JSONObject o2) {
                String s1 = String.valueOf(o1.get("day_id"));
                String s2 = String.valueOf(o2.get("day_id"));
                return  s1.compareTo(s2);  //升序
            }
        });
        return jsonObjectList;
    }

http://blog.csdn.net/linshutao/article/details/7693625
TreeMap不是按照hashCode来存放,它是按照实现的Comparable接口的compareTo这个方法来存储的

  • TreeMap(通过key)排序:
 public TreeMap<String, String> getSortTreeMapByKey(JSONArray jsonArray){
        //下面一段可用lambda表达式代替
        //TreeMap<String, String> map = new TreeMap<String, String>((o1,o2)->o2.compareTo(o1));
        TreeMap<String, String> map = new TreeMap<String, String>(new Comparator<String>(){
            public int compare(String o1,String o2){
                return  o2.compareTo(o1); //升序
            }
        });
        map.put("2017-09-30", "6");
        map.put("2017-09-29", "2");
        map.put("2017-09-28", "7");
        map.put("2017-09-27", "1");
        for(Map.Entry<String,String> entry:map.entrySet()){
            System.out.println("key:"+entry.getKey()+",:value:"+entry.getValue());
        }
         return map;
    }
  • TreeMap(通过value)排序:
 public TreeMap<String, String> getSortTreeMapByValue(JSONArray jsonArray){
        TreeMap<String, String> map = new TreeMap<>();
        map.put("zdef","rfgh");
        map.put("asrg","zfg");
        map.put("rgd","dfgh");
        map.put("cbf","gddf");
        //将Map转为List
        List<Map.Entry<String,String>> list = new ArrayList<>(map.entrySet());
        Collections.sort(list, new Comparator<Map.Entry<String, String>>() {
            public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) {
                return  o2.getValue().compareTo(o1.getValue());//降序
            }
        });
        //运用lambda表达式
        //Collections.sort(list,((o1, o2) -> o2.getValue().compareTo(o1.getValue())));
        for(Map.Entry<String,String> entry:list){
            System.out.println("key:"+entry.getKey()+",:value:"+entry.getValue());
        }
        return map;
    }

http://www.cnblogs.com/pear-lemon/archive/2015/05/28/4536152.html
HashMap的存储位置是按照key这个对象的hashCode来存放的

  • HashMap(通过key)排序( 把数据放在list里边才可以使用):
 public static Map getSortHashMapByKey(){
        Map<String, String> map = new HashMap<String, String>();
        map.put("2017-09-30", "6");
        map.put("2017-09-29", "2");
        map.put("2017-09-28", "7");
        map.put("2017-09-27", "1");

        List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>();
        list.addAll(map.entrySet());

        KeyComparator kc = new KeyComparator();//升序
        Collections.sort(list, kc);
        for (Iterator<Map.Entry<String, String>> it = list.iterator(); it
                .hasNext();) {
            System.out.println(it.next());
        }
         return map;
    }

private static class KeyComparator implements
            Comparator<Map.Entry<String, String>> {
        public int compare(Map.Entry<String, String> m,
                           Map.Entry<String, String> n) {
            return m.getKey().compareTo(n.getKey());
        }
    }
OutPut:
2017-09-27=1
2017-09-28=7
2017-09-29=2
2017-09-30=6
  • HashMap(通过value)排序( 把数据放在list里边才可以使用):
 public static Map getSortHashMapByValue(){
        Map<String, String> map = new HashMap<String, String>();
        map.put("2017-09-30", "6");
        map.put("2017-09-29", "2");
        map.put("2017-09-28", "7");
        map.put("2017-09-27", "1");

        List<Map.Entry<String, String>> list = new ArrayList<Map.Entry<String, String>>();
        list.addAll(map.entrySet());

        ValueComparator vc = new ValueComparator();//升序
        Collections.sort(list, vc);
        for (Iterator<Map.Entry<String, String>> it = list.iterator();it.hasNext();) {
            System.out.println(it.next());
        }
         return map;
    }

private static class ValueComparator implements
            Comparator<Map.Entry<String, String>> {
        public int compare(Map.Entry<String, String> m,
                           Map.Entry<String, String> n) {
            return m.getValue().compareTo(n.getValue());
        }
    }

OutPut:
2017-09-27=1
2017-09-29=2
2017-09-30=6
2017-09-28=7

  • 对象类默认排序是按某个字段,特殊情况才按另外个字段排序:
 /**
 * 苹果类
 */
public class Apple implements Comparable<Apple>{


    /**
     * 重量
     */
    private Integer weight;
    /**
     * 价格
     */
    private Integer price;

    public Integer getPrice() {
        return price;
    }

    public void setPrice(Integer price) {
        this.price = price;
    }

    public Integer getWeight() {
        return weight;
    }

    public void setWeight(Integer weight) {
        this.weight = weight;
    }

    @Override
    public String toString() {   //重写toString()方法,方面输出
        StringBuilder sb = new StringBuilder();
        sb.append("[");
        sb.append("Apple:(weight:");
        sb.append(weight);
        sb.append(",price:");
        sb.append(price);
        sb.append(")]");
        return sb.toString();
    }

    @Override
    public int compareTo(Apple o) {  //实现内部排序
        return this.price.compareTo(o.getPrice());
    }
}
public class Test {//测试类
    public static void main(String[] args) {
        List<Apple> apples = new ArrayList<>();
        Random random = new Random(12);
        for (int i = 0; i < 10; i++) {  //生成10个苹果,重量随机生成
            Apple apple = new Apple();
            apple.setWeight(random.nextInt(1000));
            apple.setPrice(random.nextInt(50));
            apples.add(apple);
        }
        for (Apple apple : apples) { //打印10个苹果的顺序
            System.out.println("apple = " + apple);
        }
       Collections.sort(apples);
        //  Collections.sort(apples,(o1,o2)->o1.getWeight().compareTo(o2.getWeight()));
        for (Apple apple : apples) {
            System.out.println(" sort apple = " + apple);
        }
    }
}
//输出
apple = [Apple:(weight:866,price:12)]
apple = [Apple:(weight:556,price:33)]
apple = [Apple:(weight:624,price:11)]
apple = [Apple:(weight:750,price:15)]
apple = [Apple:(weight:596,price:21)]
apple = [Apple:(weight:568,price:22)]
apple = [Apple:(weight:61,price:7)]
apple = [Apple:(weight:695,price:14)]
apple = [Apple:(weight:536,price:31)]
apple = [Apple:(weight:505,price:3)]
 sort apple = [Apple:(weight:505,price:3)]
 sort apple = [Apple:(weight:61,price:7)]
 sort apple = [Apple:(weight:624,price:11)]
 sort apple = [Apple:(weight:866,price:12)]
 sort apple = [Apple:(weight:695,price:14)]
 sort apple = [Apple:(weight:750,price:15)]
 sort apple = [Apple:(weight:596,price:21)]
 sort apple = [Apple:(weight:568,price:22)]
 sort apple = [Apple:(weight:536,price:31)]
 sort apple = [Apple:(weight:556,price:33)]
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,137评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,824评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,465评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,131评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,140评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,895评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,535评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,435评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,952评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,081评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,210评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,896评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,552评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,089评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,198评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,531评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,209评论 2 357

推荐阅读更多精彩内容

  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,502评论 0 3
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,266评论 0 16
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,262评论 11 349
  • 本文出自 Eddy Wiki ,转载请注明出处:http://eddy.wiki/interview-java.h...
    eddy_wiki阅读 1,162评论 0 16
  • 亲爱的陌生人: 我每天都在问自己,你是是谁?我又是谁?为什么你总是出现在那个可怜的近乎奢侈的梦里,那么近...
    整整小姐阅读 409评论 4 13