【发布时间】:2012-05-06 05:05:41
【问题描述】:
我正在尝试使用 Comparator 接口对 TreeMap(将 Double 作为值和 Integer 值作为键)进行排序,但它不起作用。
// Create a tree map
TreeMap tm = new TreeMap();
// Put elements to the map
tm.put(1, new Double(3434.34));
tm.put(0, new Double(123.22));
tm.put(4, new Double(1378.00));
tm.put(2, new Double(99.22));
tm.put(3, new Double(-19.08));
List<Map.Entry> valueList = new ArrayList(tm.entrySet());
// Collections.sort(valueList, new Sort());
Collections.sort(valueList, new Sort());
HashMap sortedMap = new HashMap();
// Get an iterator
Iterator<Map.Entry> i = valueList.iterator();
// Display elements
while (i.hasNext()) {
Map.Entry object = i.next();
sortedMap.put(object.getKey(), object.getValue());
}
List sortedList = new ArrayList(sortedMap.entrySet());
Iterator<Map.Entry> iterator = sortedList.iterator();
while (iterator.hasNext()) {
Map.Entry entry = iterator.next();
System.out.println("Value " + entry.getValue() + "\n");
}
以下是我的比较器类
public class Sort implements Comparator<Map.Entry> {
@Override
public int compare(Map.Entry o1, Map.Entry o2) {
// TODO Auto-generated method stub
double valueOne = (Double) o1.getValue();
double valueTwo = (Double) o2.getValue();
int returnValue =
valueOne > valueTwo ? -1 : (valueOne == valueTwo ? 0 : 1);
return (valueOne > valueTwo ? -1 : (valueOne == valueTwo ? 0 : 1));
}
}
但我得到以下输出
Value 123.22
Value 3434.34
Value 99.22
Value -19.08
Value 1378.0
Edited Part
public int compare(Map.Entry o1, Map.Entry o2) {
// TODO Auto-generated method stub
double valueOne = ((Double) o1.getValue()).doubleValue();
double valueTwo = ((Double) o2.getValue()).doubleValue();
int returnValue =
valueOne > valueTwo ? -1 : (valueOne == valueTwo ? 0 : 1);
return (valueOne > valueTwo ? -1 : (valueOne == valueTwo ? 0 : 1));
}
【问题讨论】:
-
你不应该将Double值与
==符号进行比较,而是尝试比较>和<,如果没有人返回值,则返回0 -
感谢您的快速回答。我使用 Double Class 中的 doubleValue() 方法将值更改为 double,但它仍然没有得到排序。请参阅我的编辑部分。
-
JDK 中没有
Map实现可以让您按值排序。