如何对HashMap键进行排序 - 它们没有排序?

时间:2013-05-28 18:49:25

标签: java

我有一个

HashMap<String, Integer>. 

我想将所有键,即字符串提取到String数组中。然后,我想对这个String数组进行排序并使用它。

不幸的是,String数组没有排序并产生我想要的输出。

当前输出为 -

one, 
two, 
zero,

需要的输出是

zero, 
one, 
two,  

代码如下 -

import java.util.Arrays;
import java.util.HashMap;
import java.util.Set;


public class HashMapKeySorter {

    public static String[] convert(HashMap<String, Integer> codes){

        Set set = codes.keySet();
        Object[] object = set.toArray();
        String[] allKeys = new String[object.length];

        for(int i = 0; i < object.length; i++){
            allKeys[i] = (String) object[i];

        }

        Arrays.sort(allKeys);
        return allKeys;

    }


    public static void main(String[]args){

         HashMap<String, Integer> hm = new HashMap<String, Integer>();

         hm.put("zero", 0);

         hm.put("one", 1);

         hm.put("two", 2);

         String[] allKeys = convert(hm);
         showStringArray(allKeys);

    }


    public static void showStringArray(String[] allKeys){

        for(int i = 0; i < allKeys.length; i++){

            System.out.println(allKeys[i] + ", ");

        }

    }

}

4 个答案:

答案 0 :(得分:10)

你接近错了。你想要的是:

1)从entrySet()获取Map

2)按照value

对条目进行排序

3)打印每个已排序条目的key

您的程序所做的是按字母顺序对key进行排序。它做得很好。

答案 1 :(得分:5)

您需要一个自定义比较器:

Arrays.sort(allKeys, new Comparator<String>()
{
    @Override
    public int compare(String o1, String o2)
    {
        // the implementation of the comparator
    }
});

答案 2 :(得分:4)

使用Arrays.sort(数组,Comparator)将您的号召替换为Arrays.sort(array)

你必须编写自己的自定义比较器,在'one'之前对'零'进行排序。

答案 3 :(得分:1)

如果您不想按字典值排序(这是您当前正在排序的那个),那么您将需要创建一个自定义比较器,它将按字符串的数字值排序(如“one”== 1)。

Java没有内置的这样的东西,所以你需要做一些编码,easyist将是一个返回数字的字符串的开关。