Ordering ist ein scharfes und leistungsstarkes Vergleichstool, das von der Guava-Klassenbibliothek bereitgestellt wird. Guava's Ordering ist leistungsfähiger als JDK Comparator. Es ist sehr einfach zu erweitern und komplexe Komparatoren können leicht konstruiert und dann zum Vergleichen von Behältern, Sortieren und anderen Vorgängen verwendet werden.
Im Wesentlichen ist eine Ordering-Instanz nichts anderes als eine spezielle Comparator-Instanz. Beim Bestellen wird einfach eine Methode verwendet, die von einem Komparator abhängt (z. B. Collections.max) und als Instanzmethode verfügbar gemacht. Darüber hinaus ermöglicht Ordering die Verkettung von Methodenaufrufen und die Erweiterung vorhandener Komparatoren.
Werfen wir einen Blick auf einige spezifische Methoden und einfache Anwendungsbeispiele beim Bestellen.
Gängige statische Methoden:
natural(): Verwenden Sie die natürliche Reihenfolge vergleichbarer Typen, zum Beispiel: Ganzzahlen sind von klein nach groß, Zeichenfolgen sind in Wörterbuchreihenfolge
usingToString( ): Verwenden Sie die von toString() zurückgegebene Zeichenfolge, um sie in Wörterbuchreihenfolge zu sortieren;
arbitrary(): Gibt eine beliebige Reihenfolge aller Objekte zurück, das heißt, Compare(a, b) == 0 ist a == b ( Identitätsgleichheit). Die Reihenfolge selbst hat keine Bedeutung, ist aber während der Lebensdauer der VM eine Konstante.
[code]import java.util.List; import org.junit.Test; import com.google.common.collect.Lists; import com.google.common.collect.Ordering; public class OrderingTest { @Test public void testStaticOrdering(){ List<String> list = Lists.newArrayList(); list.add("peida"); list.add("jerry"); list.add("harry"); list.add("eva"); list.add("jhon"); list.add("neron"); System.out.println("list:"+ list); Ordering<String> naturalOrdering = Ordering.natural(); Ordering<Object> usingToStringOrdering = Ordering.usingToString(); Ordering<Object> arbitraryOrdering = Ordering.arbitrary(); System.out.println("naturalOrdering:"+ naturalOrdering.sortedCopy(list)); System.out.println("usingToStringOrdering:"+ usingToStringOrdering.sortedCopy(list)); System.out.println("arbitraryOrdering:"+ arbitraryOrdering.sortedCopy(list)); } }
[code]list:[peida, jerry, harry, eva, jhon, neron] naturalOrdering:[eva, harry, jerry, jhon, neron, peida] usingToStringOrdering:[eva, harry, jerry, jhon, neron, peida] arbitraryOrdering:[neron, harry, eva, jerry, peida, jhon]
reverse(): Gibt die umgekehrte Reihenfolge der aktuellen Reihenfolge zurück:
nullsFirst(): Gibt eine Reihenfolge zurück, die null vor Nicht-Null-Elementen platziert, andere wie die ursprüngliche Reihenfolge;
nullsLast(): Gibt eine Reihenfolge zurück, die null nach dem Nicht-Null-Element einfügt, und der Rest ist derselbe wie die ursprüngliche Reihenfolge
Compound(Comparator): gibt zurück Eine Sortierung mit Comparator, Comparator als zweitem Sortierelement, zum Beispiel Sortieren der Fehlerliste, zuerst nach der Stufe des Fehlers und dann nach der Priorität
lexicographical(): Gibt eine iterierte Liste zurück nach Wörterbuchelementen Reihenfolge;
onResultOf(Function): Nachdem Sie die Funktion auf jedes Element angewendet haben, verwenden Sie die ursprüngliche Reihenfolge zum Sortieren;
GreatestOf(Iterable iterable, int k): Gibt den angegebenen kth zurück Das größte Element des Iterierbaren, in dieser Reihenfolge vom größten zum kleinsten. ist instabil.
leastOf(Iterable iterable,int k): Gibt das kleinste Element der angegebenen k-ten Iterable zurück, in der Reihenfolge vom kleinsten zum größten. ist instabil.
isOrdered(Iterable): Unabhängig davon, ob es geordnet ist, darf Iterable nicht weniger als 2 Elemente enthalten.
isStrictlyOrdered(Iterable): Ob es streng geordnet ist. Beachten Sie, dass ein Iterable nicht weniger als zwei Elemente haben kann.
sortedCopy(Iterable): Gibt das angegebene Element als sortierte Kopie der Liste zurück.
[code]import java.util.List; import org.junit.Test; import com.google.common.collect.ImmutableList; import com.google.common.collect.Lists; import com.google.common.collect.Ordering; public class OrderingTest { @Test public void testOrdering(){ List<String> list = Lists.newArrayList(); list.add("peida"); list.add("jerry"); list.add("harry"); list.add("eva"); list.add("jhon"); list.add("neron"); System.out.println("list:"+ list); Ordering<String> naturalOrdering = Ordering.natural(); System.out.println("naturalOrdering:"+ naturalOrdering.sortedCopy(list)); List<Integer> listReduce= Lists.newArrayList(); for(int i=9;i>0;i--){ listReduce.add(i); } List<Integer> listtest= Lists.newArrayList(); listtest.add(1); listtest.add(1); listtest.add(1); listtest.add(2); Ordering<Integer> naturalIntReduceOrdering = Ordering.natural(); System.out.println("listtest:"+ listtest); System.out.println(naturalIntReduceOrdering.isOrdered(listtest)); System.out.println(naturalIntReduceOrdering.isStrictlyOrdered(listtest)); System.out.println("naturalIntReduceOrdering:"+ naturalIntReduceOrdering.sortedCopy(listReduce)); System.out.println("listReduce:"+ listReduce); System.out.println(naturalIntReduceOrdering.isOrdered(naturalIntReduceOrdering.sortedCopy(listReduce))); System.out.println(naturalIntReduceOrdering.isStrictlyOrdered(naturalIntReduceOrdering.sortedCopy(listReduce))); Ordering<String> natural = Ordering.natural(); List<String> abc = ImmutableList.of("a", "b", "c"); System.out.println(natural.isOrdered(abc)); System.out.println(natural.isStrictlyOrdered(abc)); System.out.println("isOrdered reverse :"+ natural.reverse().isOrdered(abc)); List<String> cba = ImmutableList.of("c", "b", "a"); System.out.println(natural.isOrdered(cba)); System.out.println(natural.isStrictlyOrdered(cba)); System.out.println(cba = natural.sortedCopy(cba)); System.out.println("max:"+natural.max(cba)); System.out.println("min:"+natural.min(cba)); System.out.println("leastOf:"+natural.leastOf(cba, 2)); System.out.println("naturalOrdering:"+ naturalOrdering.sortedCopy(list)); System.out.println("leastOf list:"+naturalOrdering.leastOf(list, 3)); System.out.println("greatestOf:"+naturalOrdering.greatestOf(list, 3)); System.out.println("reverse list :"+ naturalOrdering.reverse().sortedCopy(list)); System.out.println("isOrdered list :"+ naturalOrdering.isOrdered(list)); System.out.println("isOrdered list :"+ naturalOrdering.reverse().isOrdered(list)); list.add(null); System.out.println(" add null list:"+list); System.out.println("nullsFirst list :"+ naturalOrdering.nullsFirst().sortedCopy(list)); System.out.println("nullsLast list :"+ naturalOrdering.nullsLast().sortedCopy(list)); } } //============输出============== list:[peida, jerry, harry, eva, jhon, neron] naturalOrdering:[eva, harry, jerry, jhon, neron, peida] listtest:[1, 1, 1, 2] true false naturalIntReduceOrdering:[1, 2, 3, 4, 5, 6, 7, 8, 9] listReduce:[9, 8, 7, 6, 5, 4, 3, 2, 1] true true true true isOrdered reverse :false false false [a, b, c] max:c min:a leastOf:[a, b] naturalOrdering:[eva, harry, jerry, jhon, neron, peida] leastOf list:[eva, harry, jerry] greatestOf:[peida, neron, jhon] reverse list :[peida, neron, jhon, jerry, harry, eva] isOrdered list :false isOrdered list :false add null list:[peida, jerry, harry, eva, jhon, neron, null] nullsFirst list :[null, eva, harry, jerry, jhon, neron, peida] nullsLast list :[eva, harry, jerry, jhon, neron, peida, null]
Das Obige ist der Inhalt des Java-Class Library-Guava-Ordering Comparator. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!