구아바-오더링 클래스
주문은 향상된 연결 기능, 다중 유틸리티 방법, 다중 유형 정렬 기능 등을 갖춘 강화 된 비교기로 볼 수 있습니다.
클래스 선언
다음은에 대한 선언입니다. com.google.common.collect.Ordering<T> 클래스-
@GwtCompatible
public abstract class Ordering<T>
extends Object
implements Comparator<T>
수업 방법
Sr. 아니요 | 방법 및 설명 |
---|---|
1 | static Ordering<Object> allEqual() "순서 없음"을 나타내는 모든 값을 동일하게 처리하는 순서를 반환합니다. 이 순서를 안정적인 정렬 알고리즘에 전달하면 요소의 순서가 변경되지 않습니다. |
2 | static Ordering<Object> arbitrary() 모든 객체에 대해 임의의 순서를 반환합니다. 비교 (a, b) == 0은 a == b (동일성 동일)를 의미합니다. |
삼 | int binarySearch(List<? extends T> sortedList, T key) 이진 검색 알고리즘을 사용하여 sortedList에서 키를 검색합니다. |
4 | abstract int compare(T left, T right) 순서에 대한 두 인수를 비교합니다. |
5 | <U extends T> Ordering<U> compound(Comparator<? super U> secondaryComparator) 이 순서를 처음 사용하는 순서를 반환하지만 "동점"인 경우에는 secondaryComparator에 위임합니다. |
6 | static <T> Ordering<T> compound(Iterable<? extends Comparator<? super T>> comparators) 0이 아닌 결과를 찾을 때까지 지정된 각 비교기를 순서대로 시도하고 해당 결과를 반환하고 모든 비교기가 0을 반환하는 경우에만 0을 반환하는 순서를 반환합니다. |
7 | static <T> Ordering<T> explicit(List<T> valuesInOrder) 주어진 목록에 나타나는 순서에 따라 객체를 비교하는 순서를 반환합니다. |
8 | static <T> Ordering<T> explicit(T leastValue, T... remainingValuesInOrder) 이 메서드에 주어진 순서에 따라 객체를 비교하는 순서를 반환합니다. |
9 | static <T> Ordering<T> from(Comparator<T> comparator) 기존 비교기 인스턴스를 기반으로 순서를 반환합니다. |
10 | <E extends T> List<E> greatestOf(Iterable<E> iterable, int k) 이 순서에 따라 주어진 iterable의 가장 큰 요소 k 개를 가장 큰 것에서 가장 작은 것 순으로 반환합니다. |
11 | <E extends T> List<E> greatestOf(Iterator<E> iterator, int k) 이 순서에 따라 주어진 반복기에서 가장 큰 요소에서 가장 작은 요소 순으로 k 개의 가장 큰 요소를 반환합니다. |
12 | <E extends T> ImmutableList<E> immutableSortedCopy(Iterable<E> elements) 이 순서로 정렬 된 요소를 포함하는 변경 불가능한 목록을 리턴합니다. |
13 | boolean isOrdered(Iterable<? extends T> iterable) 첫 번째 이후의 iterable의 각 요소가이 순서에 따라 이전 요소보다 크거나 같으면 true를 리턴합니다. |
14 | boolean isStrictlyOrdered(Iterable<? extends T> iterable) 이 순서에 따라 첫 번째 이후의 iterable의 각 요소가 이전 요소보다 엄격하게 큰 경우 true를 반환합니다. |
15 | <E extends T> List<E> leastOf(Iterable<E> iterable, int k) 이 순서에 따라 주어진 iterable의 k 개의 최소 요소를 최소에서 최대 순으로 반환합니다. |
16 | <E extends T> List<E> leastOf(Iterator<E> elements, int k) 이 순서에 따라 지정된 반복기에서 최소 요소에서 최대 요소 순으로 k 개의 최소 요소를 반환합니다. |
17 | <S extends T> Ordering<Iterable<S>> lexicographical() 0이 아닌 결과를 찾을 때까지 해당 요소를 쌍으로 비교하여 반복 가능한 항목을 정렬하는 새로운 순서를 반환합니다. "사전 순서"를 부과합니다. |
18 | <E extends T> E max(E a, E b) 이 순서에 따라 두 값 중 큰 값을 반환합니다. |
19 | <E extends T> E max(E a, E b, E c, E... rest) 이 순서에 따라 지정된 값 중 가장 큰 값을 반환합니다. |
20 | <E extends T> E max(Iterable<E> iterable) 이 순서에 따라 지정된 값 중 가장 큰 값을 반환합니다. |
21 | <E extends T> E max(Iterator<E> iterator) 이 순서에 따라 지정된 값 중 가장 큰 값을 반환합니다. |
22 | <E extends T> E min(E a, E b) 이 순서에 따라 두 값 중 작은 값을 반환합니다. |
23 | <E extends T> E min(E a, E b, E c, E... rest) 이 순서에 따라 지정된 값 중 최소값을 반환합니다. |
24 | <E extends T> E min(Iterable<E> iterable) 이 순서에 따라 지정된 값 중 최소값을 반환합니다. |
25 | <E extends T> E min(Iterator<E> iterator) 이 순서에 따라 지정된 값 중 최소값을 반환합니다. |
26 | static <C extends Comparable> Ordering<C> natural() 값의 자연 순서를 사용하는 직렬화 가능한 순서를 반환합니다. |
27 | <S extends T> Ordering<S> nullsFirst() null을 다른 모든 값보다 작게 처리하고이를 사용하여 null이 아닌 값을 비교하는 순서를 반환합니다. |
28 | <S extends T> Ordering<S> nullsLast() null을 다른 모든 값보다 큰 것으로 취급하고이 순서를 사용하여 null이 아닌 값을 비교하는 순서를 반환합니다. |
29 | <F> Ordering<F> onResultOf(Function<F,? extends T> function) 먼저 함수를 적용한 다음이를 사용하여 해당 결과를 비교하여 요소를 정렬하는 F에 대한 새로운 순서를 반환합니다. |
30 | <S extends T> Ordering<S> reverse() 이 순서의 반대를 리턴합니다. Collections.reverseOrder (Comparator)에 해당하는 Ordering |
31 | <E extends T> List<E> sortedCopy(Iterable<E> elements) 이 순서로 정렬 된 요소를 포함하는 변경 가능한 목록을 리턴합니다. 결과 목록에 추가 수정이 필요하거나 null을 포함 할 수있는 경우에만 이것을 사용하십시오. |
32 | static Ordering<Object> usingToString() toString ()에 의해 반환 된 문자열 표현의 자연스러운 순서로 객체를 비교하는 순서를 반환합니다. |
상속 된 메서드
이 클래스는 다음 클래스에서 메서드를 상속합니다-
- java.lang.Object
주문 클래스의 예
원하는 편집기를 사용하여 다음 Java 프로그램을 만듭니다. C:/> Guava.
GuavaTester.java
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import com.google.common.collect.Ordering;
public class GuavaTester {
public static void main(String args[]) {
List<Integer> numbers = new ArrayList<Integer>();
numbers.add(new Integer(5));
numbers.add(new Integer(2));
numbers.add(new Integer(15));
numbers.add(new Integer(51));
numbers.add(new Integer(53));
numbers.add(new Integer(35));
numbers.add(new Integer(45));
numbers.add(new Integer(32));
numbers.add(new Integer(43));
numbers.add(new Integer(16));
Ordering ordering = Ordering.natural();
System.out.println("Input List: ");
System.out.println(numbers);
Collections.sort(numbers,ordering );
System.out.println("Sorted List: ");
System.out.println(numbers);
System.out.println("======================");
System.out.println("List is sorted: " + ordering.isOrdered(numbers));
System.out.println("Minimum: " + ordering.min(numbers));
System.out.println("Maximum: " + ordering.max(numbers));
Collections.sort(numbers,ordering.reverse());
System.out.println("Reverse: " + numbers);
numbers.add(null);
System.out.println("Null added to Sorted List: ");
System.out.println(numbers);
Collections.sort(numbers,ordering.nullsFirst());
System.out.println("Null first Sorted List: ");
System.out.println(numbers);
System.out.println("======================");
List<String> names = new ArrayList<String>();
names.add("Ram");
names.add("Shyam");
names.add("Mohan");
names.add("Sohan");
names.add("Ramesh");
names.add("Suresh");
names.add("Naresh");
names.add("Mahesh");
names.add(null);
names.add("Vikas");
names.add("Deepak");
System.out.println("Another List: ");
System.out.println(names);
Collections.sort(names,ordering.nullsFirst().reverse());
System.out.println("Null first then reverse sorted list: ");
System.out.println(names);
}
}
결과 확인
다음을 사용하여 클래스 컴파일 javac 다음과 같이 컴파일러-
C:\Guava>javac GuavaTester.java
이제 GuavaTester를 실행하여 결과를 확인하십시오.
C:\Guava>java GuavaTester
결과를 확인하십시오.
Input List:
[5, 2, 15, 51, 53, 35, 45, 32, 43, 16]
Sorted List:
[2, 5, 15, 16, 32, 35, 43, 45, 51, 53]
======================
List is sorted: true
Minimum: 2
Maximum: 53
Reverse: [53, 51, 45, 43, 35, 32, 16, 15, 5, 2]
Null added to Sorted List:
[53, 51, 45, 43, 35, 32, 16, 15, 5, 2, null]
Null first Sorted List:
[null, 2, 5, 15, 16, 32, 35, 43, 45, 51, 53]
======================
Another List:
[Ram, Shyam, Mohan, Sohan, Ramesh, Suresh, Naresh, Mahesh, null, Vikas, Deepak]
Null first then reverse sorted list:
[Vikas, Suresh, Sohan, Shyam, Ramesh, Ram, Naresh, Mohan, Mahesh, Deepak, null]