【发布时间】:2011-07-26 23:11:35
【问题描述】:
我想要一个仅基于键排序的c.g.c.c.Multimap。这些值不应该被排序。我尝试用番石榴的TreeMultimap 构建一些东西,但是我不能使用它,因为值类型没有实现Comparable。
public class MyObject /* doesn't implement Comparable */ {
private String name;
private int score;
// Getters/setters are implemented
public static Function<MyObject,Integer> myObjectToScore {
@Override public Integer apply (MyObject o) { return o.score; }
}
public static Multimap<Integer,MyObject> indexOnScore(Iterable<MyObject> i) {
Multimap<Integer,MyObject> m = Multimaps.index(i, myObjectToScore());
// Do the sort of the keys.
return m;
}
}
我曾考虑过获取键的SortedSet,然后遍历排序集中的每个键以获取各种值,但我希望使用 Guava 中现有的(尚未发现的)功能,而不是使用这种hack。
注意:我不会让MyObject 实现Comparable,因为它对我的实际对象没有意义。
输入/输出示例:
Set<MyObject> s = Sets.newHashSet(
new MyObject("a", 2),
new MyObject("b", 3),
new MyObject("c", 1),
new MyObject("d", 3),
new MyObject("e", 1)
); // Assuming constructor MyObject(String name, int score)
for (Map.Entry<Integer, MyObject> e: MyObject.indexedOnScore(s).entries()) {
System.out.printf("%d -> %s%n", e.getKey(), e.getValue().getName());
}
打印:
1 -> c // or switched with line below
1 -> e
2 -> a
3 -> b // or switched with line below
3 -> d
【问题讨论】:
-
你能举个例子输入/输出
-
@Dan:是的,我确实知道那门课,但我在这里说的是 Guava 的
Multimaps,而不是Map。 -
什么是c.g.c.c?请不要在问题中使用这样的缩写。
标签: java sorting guava multimap