本文整理匯總了Java中org.eclipse.collections.impl.block.factory.Comparators類的典型用法代碼示例。如果您正苦於以下問題:Java Comparators類的具體用法?Java Comparators怎麽用?Java Comparators使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Comparators類屬於org.eclipse.collections.impl.block.factory包,在下文中一共展示了Comparators類的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: validateNoBaselineBreaks
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
public void validateNoBaselineBreaks(DbDeployerAppContext appContext, Predicate<? super CompareBreak> breakIgnorePredicate) {
MutableList<CompareBreak> sortedCompareBreaks = this.calculateBaselineBreaks(appContext).toList().sortThis(
Comparators.fromFunctions(
CompareBreak.TO_COMPARE_SUBJECT,
Functions.chain(CompareBreak.TO_CLAZZ, CLASS_TO_NAME),
Functions.chain(Functions.getToClass(), CLASS_TO_NAME)
));
MutableList<CompareBreak> relevantBreaks = sortedCompareBreaks.reject(breakIgnorePredicate);
LOG.info("Found " + relevantBreaks.size() + " breaks");
if (!relevantBreaks.isEmpty()) {
throw new IllegalArgumentException(
"Found some mismatches between your change alters (LEFT) and your baseline files (RIGHT). Please review:\n"
+ relevantBreaks.makeString("\n"));
}
}
示例2: getColumnsOrderedBySelectivity
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
private MutableList<IndexMap> getColumnsOrderedBySelectivity(MutableList<UnmatchedIndexMap> allMissingRows, MutableList<UnmatchedIndexMap> allSurplusRows, MutableList<IndexMap> columnIndices)
{
LOGGER.info("Calculating column selectivity");
MutableList<Pair<IndexMap, Integer>> columnSelectivities = Lists.mutable.of();
for (IndexMap column : columnIndices)
{
CellComparator expectedComparator = this.columnComparators.getComparator(expectedData.getColumnName(column.getExpectedIndex()));
Set<String> expectedValues = getColumnValues(allMissingRows, Functions.chain(expectedValueFunction(column), expectedComparator.getFormatter()));
CellComparator actualComparator = this.columnComparators.getComparator(actualData.getColumnName(column.getActualIndex()));
Set<String> actualValues = getColumnValues(allSurplusRows, Functions.chain(actualValueFunction(column), actualComparator.getFormatter()));
actualValues.retainAll(expectedValues);
int selectivity = actualValues.size();
if (selectivity > 0)
{
columnSelectivities.add(Tuples.pair(column, Integer.valueOf(selectivity)));
}
}
return columnSelectivities
.sortThis(Comparators.reverse(Comparators.byFunction(Functions.<Integer>secondOfPair())))
.collect(Functions.<IndexMap>firstOfPair());
}
示例3: testBasicOrderingWithComparator
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
@Test
public void testBasicOrderingWithComparator() {
SortableDependency sp1 = newVertex("sp1");
SortableDependency sp2 = newVertex("sp2");
SortableDependency sp3 = newVertex("sp3");
SortableDependency sp4 = newVertex("sp4");
SortableDependency sp5 = newVertex("sp5");
DirectedGraph<SortableDependency, DefaultEdge> graph = new DefaultDirectedGraph<SortableDependency, DefaultEdge>(DefaultEdge.class);
for (SortableDependency vertex : shuffledList(sp1, sp2, sp3, sp4, sp5)) {
graph.addVertex(vertex);
}
graph.addEdge(sp1, sp5);
graph.addEdge(sp3, sp5);
graph.addEdge(sp2, sp1);
graph.addEdge(sp5, sp4);
ListIterable<SortableDependency> sorted = sorter.sortChanges(graph, Comparators.fromFunctions(SortableDependency.TO_CHANGE_NAME));
// First, compare the root topological order (i.e. ensure that the dependencies are respected)
assertEquals(5, sorted.size());
assertThat(sorted.indexOf(sp1), greaterThan(sorted.indexOf(sp2)));
assertThat(sorted.indexOf(sp5), greaterThan(sorted.indexOf(sp1)));
assertThat(sorted.indexOf(sp5), greaterThan(sorted.indexOf(sp3)));
assertThat(sorted.indexOf(sp4), greaterThan(sorted.indexOf(sp5)));
// Now check that we can achieve a consistent order too (for easier debuggability for clients)
assertEquals(Lists.immutable.with(sp2, sp1, sp3, sp5, sp4), sorted);
}
示例4: compareTo
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
@Override
public int compareTo(User o) {
Comparator c = Comparators.naturalOrder();
if (this.id == null && o.id == null)
return c.compare(this.login, o.login);
else
return c.compare(this.id, o.id);
}
示例5: searchExtraViewInfo
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
@Override
public ImmutableCollection<ExtraRerunnableInfo> searchExtraViewInfo(DaSchema schema, String tableName, Connection conn) throws SQLException {
String query = String.format("select obj.name name, com.number number, colid2 colid2, colid colid, text text\n" +
"from %1$s..syscomments com\n" +
", %1$s..sysobjects obj\n" +
" , " + schema.getName() + "..sysusers sch\n" +
"where com.id = obj.id\n" +
"and com.texttype = 0\n" +
"and obj.type in ('V')\n" +
"and obj.uid = sch.uid and sch.name = '" + schema.getSubschemaName() + "'\n" +
"order by com.id, number, colid2, colid\n", schema.getName());
QueryRunner qr = new QueryRunner(); // using queryRunner so that we can reuse the connection
ImmutableList<Map<String, Object>> maps = ListAdapter.adapt(qr.query(conn, query, new MapListHandler())).toImmutable();
ImmutableList<ExtraRerunnableInfo> viewInfos = maps.collect(new Function<Map<String, Object>, ExtraRerunnableInfo>() {
@Override
public ExtraRerunnableInfo valueOf(Map<String, Object> object) {
return new ExtraRerunnableInfo(
(String) object.get("name"),
null,
(String) object.get("text"),
null,
((Integer) object.get("colid2")).intValue(),
((Integer) object.get("colid")).intValue()
);
}
});
return viewInfos.groupBy(ExtraRerunnableInfo.TO_NAME).multiValuesView().collect(new Function<RichIterable<ExtraRerunnableInfo>, ExtraRerunnableInfo>() {
@Override
public ExtraRerunnableInfo valueOf(RichIterable<ExtraRerunnableInfo> objectInfos) {
MutableList<ExtraRerunnableInfo> sortedInfos = objectInfos.toSortedList(Comparators.fromFunctions(ExtraRerunnableInfo.TO_ORDER2, ExtraRerunnableInfo.TO_ORDER1));
StringBuilder definitionString = sortedInfos.injectInto(new StringBuilder(), new Function2<StringBuilder, ExtraRerunnableInfo, StringBuilder>() {
@Override
public StringBuilder value(StringBuilder sb, ExtraRerunnableInfo rerunnableInfo) {
return sb.append(rerunnableInfo.getDefinition());
}
});
return new ExtraRerunnableInfo(
sortedInfos.get(0).getName(),
null,
definitionString.toString()
);
}
}).toList().toImmutable();
}
示例6: searchExtraRoutines
import org.eclipse.collections.impl.block.factory.Comparators; //導入依賴的package包/類
@Override
public ImmutableCollection<DaRoutine> searchExtraRoutines(final DaSchema schema, String procedureName, Connection conn) throws SQLException {
String nameClause = procedureName != null ? "and obj.name = '" + procedureName + "'\n" : "";
String query = String.format("select obj.name name, obj.type type, com.number number, colid2 colid2, colid colid, text text\n" +
"from %1$s..syscomments com\n" +
", %1$s..sysobjects obj\n" +
" , " + schema.getName() + "..sysusers sch\n" +
"where com.id = obj.id\n" +
"and com.texttype = 0\n" +
"and obj.uid = sch.uid and sch.name = '" + schema.getSubschemaName() + "'\n" +
"and obj.type in ('SF', 'P')\n" +
nameClause +
"order by com.id, number, colid2, colid\n", schema.getName());
QueryRunner qr = new QueryRunner(); // using queryRunner so that we can reuse the connection
ImmutableList<Map<String, Object>> maps = ListAdapter.adapt(qr.query(conn, query, new MapListHandler())).toImmutable();
ImmutableList<ExtraRerunnableInfo> routineInfos = maps.collect(new Function<Map<String, Object>, ExtraRerunnableInfo>() {
@Override
public ExtraRerunnableInfo valueOf(Map<String, Object> object) {
String basename = (String) object.get("name");
int number = ((Integer) object.get("number")).intValue();
String specificName = number > 1 ? basename + ";" + number : basename;
return new ExtraRerunnableInfo(
basename,
specificName,
(String) object.get("text"),
((String) object.get("type")).trim(),
((Integer) object.get("colid2")).intValue(),
((Integer) object.get("colid")).intValue()
);
}
});
return routineInfos.groupBy(ExtraRerunnableInfo.TO_SPECIFIC_NAME).multiValuesView().collect(new Function<RichIterable<ExtraRerunnableInfo>, DaRoutine>() {
@Override
public DaRoutine valueOf(RichIterable<ExtraRerunnableInfo> objectInfos) {
MutableList<ExtraRerunnableInfo> sortedInfos = objectInfos.toSortedList(Comparators.fromFunctions(ExtraRerunnableInfo.TO_ORDER2, ExtraRerunnableInfo.TO_ORDER1));
StringBuilder definitionString = sortedInfos.injectInto(new StringBuilder(), new Function2<StringBuilder, ExtraRerunnableInfo, StringBuilder>() {
@Override
public StringBuilder value(StringBuilder sb, ExtraRerunnableInfo rerunnableInfo) {
return sb.append(rerunnableInfo.getDefinition());
}
});
return new DaRoutinePojoImpl(
sortedInfos.get(0).getName(),
schema,
sortedInfos.get(0).getType().equals("P") ? DaRoutineType.procedure : DaRoutineType.function,
sortedInfos.get(0).getSpecificName(),
definitionString.toString()
);
}
}).toList().toImmutable();
}