अमरूद - ऑर्डरिंग क्लास

ऑर्डरिंग को एक समृद्ध तुलनित्र के रूप में बढ़ाया जा सकता है, जिसमें बेहतर चैनिंग फंक्शनलिटी, मल्टीपल यूटिलिटी मेथड, मल्टी-टाइप सॉर्टिंग क्षमता आदि शामिल हैं।

वर्ग घोषणा

निम्नलिखित के लिए घोषणा है com.google.common.collect.Ordering<T> वर्ग -

@GwtCompatible
public abstract class Ordering<T>
   extends Object
      implements Comparator<T>

कक्षा के तरीके

अनु क्रमांक विधि और विवरण
1

static Ordering<Object> allEqual()

एक आदेश देता है जो सभी मूल्यों को समान मानता है, जो "कोई आदेश नहीं" दर्शाता है। किसी भी स्थिर सॉर्ट एल्गोरिथ्म के लिए इस आदेश को पास करने से तत्वों के क्रम में कोई बदलाव नहीं होता है।

2

static Ordering<Object> arbitrary()

सभी वस्तुओं पर एक मनमाना आदेश देता है, जिसके लिए (ए, बी) == 0 का तात्पर्य है == बी (पहचान समानता)।

3

int binarySearch(List<? extends T> sortedList, T key)

बाइनरी खोज एल्गोरिथ्म का उपयोग करके कुंजी के लिए सॉर्टेड लिस्ट।

4

abstract int compare(T left, T right)

आदेश के लिए अपने दो तर्कों की तुलना करता है।

5

<U extends T> Ordering<U> compound(Comparator<? super U> secondaryComparator)

एक आदेश लौटाता है जो पहले इस आदेश का उपयोग करता है, लेकिन जो एक "टाई" की स्थिति में होता है, फिर द्वितीयक प्रतिनिधि को सौंपता है।

6

static <T> Ordering<T> compound(Iterable<? extends Comparator<? super T>> comparators)

एक आदेश देता है जो प्रत्येक दिए गए तुलनित्र को तब तक क्रम में रखने की कोशिश करता है जब तक कि एक गैर-शून्य परिणाम नहीं मिलता है, उस परिणाम को लौटाता है, और शून्य वापस केवल तभी मिलता है जब सभी तुलनित्र शून्य लौट आते हैं।

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)

इस आदेश के अनुसार दिए गए पुन: उपयोग के k सबसे महान तत्वों को, सबसे बड़े से कम से कम में लौटाता है।

1 1

<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)

इस आदेश के अनुसार, पहले के बाद चलने-फिरने वाले प्रत्येक तत्व से अधिक या उसके बराबर होने वाले तत्व के बराबर होने पर यह सही है।

14

boolean isStrictlyOrdered(Iterable<? extends T> iterable)

सही है अगर पहली के बाद चलने योग्य प्रत्येक तत्व इस आदेश के अनुसार, उस तत्व से कड़ाई से अधिक है, जो सही है

15

<E extends T> List<E> leastOf(Iterable<E> iterable, int k)

दिए गए आदेशों के कम से कम तत्वों को इस क्रम के अनुसार लौटाता है, ताकि कम से कम सबसे बड़ी से।

16

<E extends T> List<E> leastOf(Iterator<E> elements, int k)

इस क्रम के अनुसार दिए गए पुनरावृत्त से कम से कम तत्वों को लौटाता है, ताकि कम से कम सबसे बड़ी से।

17

<S extends T> Ordering<Iterable<S>> lexicographical()

एक नया आदेश देता है जो एक गैर-परिणाम प्राप्त होने तक जोड़े जाने वाले तत्वों की तुलना करके पुनरावृत्तियों को क्रमबद्ध करता है; "डिक्शनरी ऑर्डर" लगाता है।

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()

एक ऐसा आदेश लौटाता है जो अन्य सभी मानों की तुलना में कम व्यवहार करता है और इसका उपयोग गैर-शून्य मानों की तुलना करने के लिए करता है।

28

<S extends T> Ordering<S> nullsLast()

एक आदेश देता है जो अशक्त को अन्य सभी मूल्यों से अधिक मानता है और गैर-शून्य मानों की तुलना करने के लिए इस आदेश का उपयोग करता है।

29

<F> Ordering<F> onResultOf(Function<F,? extends T> function)

एफ पर एक नया आदेश देता है जो पहले उन पर एक फ़ंक्शन लागू करके तत्वों का आदेश देता है, फिर उन परिणामों की तुलना करके इसका उपयोग करता है।

30

<S extends T> Ordering<S> reverse()

इस आदेश का उलटा लौटाता है; कलेक्शंस के बराबर ऑर्डर करना ।reverseOrder (तुलनित्र)।

31

<E extends T> List<E> sortedCopy(Iterable<E> elements)

इस क्रम से क्रमबद्ध तत्वों वाले एक उत्परिवर्तित सूची लौटाता है; इसका उपयोग केवल तब करें जब परिणामी सूची को और अधिक संशोधन की आवश्यकता हो सकती है, या इसमें अशक्त हो सकता है।

32

static Ordering<Object> usingToString()

एक आदेश देता है जो वस्तुओं की तुलना उनके स्ट्रिंग निरूपण के प्राकृतिक क्रम से करता है जैसा कि स्ट्रींग () द्वारा लौटाया गया है।

तरीके निहित हैं

इस वर्ग को निम्न वर्ग से विधियाँ प्राप्त होती हैं -

  • java.lang.Object

ऑर्डरिंग क्लास का उदाहरण

अपनी पसंद के किसी भी संपादक का उपयोग करके निम्नलिखित जावा प्रोग्राम बनाएं 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]