java – Guava:如何从列表和单个元素创建显式排序?
发布时间:2020-12-14 16:25:09 所属栏目:Java 来源:网络整理
导读:在Guava中,给予Collection E和我知道的E类元素e在集合中,我想创建一个自定义的 OrderingE ,首先排序,然后排序其余的集合.然而,到达那里的方式似乎很复杂: CollectionString values = ImmutableList.of("apples","oranges","pears");String first = "oranges
在Guava中,给予Collection< E>和我知道的E类元素e在集合中,我想创建一个自定义的
Ordering<E> ,首先排序,然后排序其余的集合.然而,到达那里的方式似乎很复杂:
Collection<String> values = ImmutableList.of("apples","oranges","pears"); String first = "oranges"; List<String> remainingValues = newArrayList(values); // this remainingValues.remove(first); // seems Ordering<String> myOrdering = // very Ordering.explicit(first,remainingValues.toArray( // complicated! new String[remainingValues.size()])); // is there an easier way? 我想要的是这样的东西: Ordering.explicit(first); (我希望这样首先排序开始,并保留所有其他元素的顺序,但文档表示生成的Ordering将抛出未明确列出的元素的ClassCastException.) 或者像这样: Ordering.explicit(first,values.toArray(/* etc */)); (但这会失败,因为首先是一个重复的值) 有人可以提出一个简洁的做法吗? BTW,它不一定是一个Ordering,它也可以是在指定的顺序中创建一个Iterable的解决方法,但是这又是非常复杂的: Iterable<String> sorted = Iterables.concat( ImmutableList.of(first),Iterables.filter(values,not(equalTo(first)))); 解决方法
那么这里有一种方法,但是你可能找不到更好的方法.
final String special = "oranges"; Collections.sort( list,new Comparator<String>() { public int compare(String left,String right) { return ComparisonChain.start() .compareTrueFirst(left.equals(special),right.equals(special)) .compare(left,right) .result(); } }); ComparisonChain docs Relevant Guava feature request – 请添加任何细节. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |