구아바-오더링 클래스

주문은 향상된 연결 기능, 다중 유틸리티 방법, 다중 유형 정렬 기능 등을 갖춘 강화 된 비교기로 볼 수 있습니다.

클래스 선언

다음은에 대한 선언입니다. 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]