温故而知新(一)TreeMap

TreeMap一种”有序”的Map


import java.util.Map;
import java.util.TreeMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Comparator;

public class SortMap {
    public static void main(String[] args) {
        TreeMap<String, Integer> map = new TreeMap<String, Integer>();
        for (String s : args) {
            map.put(s, 1);
        }
        System.out.println("------------------------------default----------------------------");
        print(map);
        System.out.println("------------------------------o2 compareTo o1----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return o2.compareTo(o1);
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);
        System.out.println("------------------------------0----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return 0;
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);
        System.out.println("------------------------------1----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return 1;
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);
        System.out.println("------------------------------2----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return 2;
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);

        System.out.println("------------------------------- -1----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return -1;
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);
        System.out.println("------------------------------ -2----------------------------");
        map = new TreeMap<String, Integer>(new Comparator<String>() {

            @Override
            public int compare(String o1, String o2) {
                return -2;
            }

        });
        for (String s : args) {
            map.put(s, 1);
        }
        print(map);
    }


    public static void print(Map<String, Integer> map) {
        Iterator<Entry<String, Integer>> it = map.entrySet().iterator();
        while (it.hasNext()) {
            Entry<String, Integer> entry = it.next();
            System.out.println(entry.getKey() + " --- ");
        }
    }
}

运行结果图:
这里写图片描述

从运行结果可以看出,大于0则是正序,小于0是倒序,当是0的时候只会打印一个值,而正序倒序就是自定义的顺序。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值