Guava - Guida rapida

Cos'è Guava?

Guava è una libreria open source basata su Java e contiene molte librerie principali di Google, che vengono utilizzate in molti dei loro progetti. Facilita le migliori pratiche di codifica e aiuta a ridurre gli errori di codifica. Fornisce metodi di utilità per raccolte, memorizzazione nella cache, supporto di primitive, concorrenza, annotazioni comuni, elaborazione di stringhe, I / O e convalide.

Benefici di Guava

  • Standardized - La libreria Guava è gestita da Google.

  • Efficient - È un'estensione affidabile, veloce ed efficiente della libreria standard Java.

  • Optimized - La libreria è altamente ottimizzata.

  • Functional Programming - Aggiunge capacità di elaborazione funzionale a Java.

  • Utilities - Fornisce molte classi di utilità che sono regolarmente richieste nello sviluppo di applicazioni di programmazione.

  • Validation - Fornisce un meccanismo di convalida fail-safe standard.

  • Best Practices - Sottolinea le migliori pratiche.

Considera il seguente frammento di codice.

public class GuavaTester {
   public static void main(String args[]) {
      GuavaTester guavaTester = new GuavaTester();
      
      Integer a =  null;
      Integer b =  new Integer(10);
      System.out.println(guavaTester.sum(a,b));
   }

   public Integer sum(Integer a, Integer b) {
      return a + b;
   }	
}

Eseguire il programma per ottenere il seguente risultato.

Exception in thread "main" java.lang.NullPointerException
   at GuavaTester.sum(GuavaTester.java:13)
   at GuavaTester.main(GuavaTester.java:9)

Di seguito sono riportati i problemi con il codice.

  • sum () non si prende cura di nessuno dei parametri da passare come null.

  • anche la funzione chiamante non si preoccupa di passare accidentalmente un valore nullo al metodo sum ().

  • Quando il programma viene eseguito, si verifica NullPointerException.

Per evitare i problemi di cui sopra, deve essere effettuato un controllo nullo in ogni luogo in cui sono presenti tali problemi.

Vediamo l'uso di Optional, una classe Utility fornita da Guava, per risolvere i problemi di cui sopra in modo standardizzato.

import com.google.common.base.Optional;

public class GuavaTester {
   public static void main(String args[]) {
      GuavaTester guavaTester = new GuavaTester();

      Integer invalidInput = null;
      Optional<Integer> a =  Optional.of(invalidInput);
      Optional<Integer> b =  Optional.of(new Integer(10));
      System.out.println(guavaTester.sum(a,b));      
   }

   public Integer sum(Optional<Integer> a, Optional<Integer> b) {
      return a.get() + b.get();
   }	
}

Eseguire il programma per ottenere il seguente risultato.

Exception in thread "main" java.lang.NullPointerException
	at com.google.common.base.Preconditions.checkNotNull(Preconditions.java:210)
	at com.google.common.base.Optional.of(Optional.java:85)
	at GuavaTester.main(GuavaTester.java:8)

Comprendiamo i concetti importanti del programma sopra.

  • Optional - Una classe di utilità, per fare in modo che il codice utilizzi correttamente il valore null.

  • Optional.of- Restituisce l'istanza della classe opzionale da utilizzare come parametro. Controlla il valore passato, non essere "nullo".

  • Optional.get - Ottiene il valore dell'input memorizzato nella classe Optional.

Utilizzando la classe Facoltativo, è possibile verificare se il metodo del chiamante sta passando un parametro appropriato o meno.

Configurazione dell'ambiente locale

Se sei ancora disposto a configurare il tuo ambiente per il linguaggio di programmazione Java, questa sezione ti guiderà su come scaricare e configurare Java sulla tua macchina. Seguire i passaggi indicati di seguito per configurare l'ambiente.

Java SE è disponibile gratuitamente dal collegamento Scarica Java . Quindi scarichi una versione basata sul tuo sistema operativo.

Segui le istruzioni per scaricare Java ed eseguire il file .exeper installare Java sulla tua macchina. Dopo aver installato Java sulla macchina, è necessario impostare le variabili di ambiente in modo che puntino alle directory di installazione corrette -

Configurazione del percorso per Windows 2000 / XP

Supponiamo che tu abbia installato Java nella directory c: \ Program Files \ java \ jdk -

  • Fare clic con il pulsante destro del mouse su "Risorse del computer" e selezionare "Proprietà".

  • Fare clic sul pulsante "Variabili d'ambiente" nella scheda "Avanzate".

  • Ora, modifica la variabile "Path" in modo che contenga anche il percorso dell'eseguibile Java. Ad esempio, se il percorso è attualmente impostato su "C: \ WINDOWS \ SYSTEM32", modificare il percorso in "C: \ WINDOWS \ SYSTEM32; c: \ Program Files \ java \ jdk \ bin".

Impostazione del percorso per Windows 95/98 / ME

Supponiamo che tu abbia installato Java nella directory c: \ Program Files \ java \ jdk -

  • Modifica il file "C: \ autoexec.bat" e aggiungi la seguente riga alla fine: "SET PATH =% PATH%; C: \ Program Files \ java \ jdk \ bin"

Configurazione del percorso per Linux, UNIX, Solaris, FreeBSD

La variabile d'ambiente PATH dovrebbe essere impostata in modo che punti a dove sono stati installati i binari Java. Fare riferimento alla documentazione della shell se si hanno problemi a farlo.

Esempio, se usi bash come shell, aggiungi la seguente riga alla fine di '.bashrc: export PATH = / path / to / java: $ PATH'

Editor Java popolari

Per scrivere i tuoi programmi Java, hai bisogno di un editor di testo. Ci sono molti IDE sofisticati disponibili sul mercato. Ma per ora, puoi considerare uno dei seguenti:

  • Notepad - Su una macchina Windows puoi usare qualsiasi semplice editor di testo come Blocco note (consigliato per questo tutorial), TextPad.

  • Netbeans - È un IDE Java open-source e gratuito da cui è possibile scaricare https://www.netbeans.org/index.html.

  • Eclipse - È anche un IDE Java sviluppato dalla comunità open source di eclipse e può essere scaricato da https://www.eclipse.org/.

Scarica Guava Archive

Scarica l'ultima versione del file jar Guava da guava-18.0.jar . Al momento della stesura di questo tutorial, abbiamo scaricato guava-18.0.jar e copiato nella cartella C: \> Guava.

OS Nome dell'archivio
finestre guava-18.0.jar
Linux guava-18.0.jar
Mac guava-18.0.jar

Imposta l'ambiente Guava

Impostare il Guava_HOMEvariabile di ambiente in modo che punti alla posizione della directory di base in cui è archiviato il vaso Guava sulla macchina. Supponendo, abbiamo estratto guava-18.0.jar nella cartella Guava su vari sistemi operativi come segue.

OS Produzione
finestre Imposta la variabile d'ambiente Guava_HOME su C: \ Guava
Linux export Guava_HOME = / usr / local / Guava
Mac export Guava_HOME = / Library / Guava

Imposta la variabile CLASSPATH

Impostare il CLASSPATHvariabile di ambiente in modo che punti alla posizione del vaso Guava. Supponendo che tu abbia memorizzato guava-18.0.jar nella cartella Guava su vari sistemi operativi come segue.

OS Produzione
finestre Imposta la variabile d'ambiente CLASSPATH su% CLASSPATH%;% Guava_HOME% \ guava-18.0.jar;.;
Linux export CLASSPATH = $ CLASSPATH: $ Guava_HOME / guava-18.0.jar :.
Mac export CLASSPATH = $ CLASSPATH: $ Guava_HOME / guava-18.0.jar :.

Facoltativo è un oggetto immutabile utilizzato per contenere un oggetto non nullo. L'oggetto facoltativo viene utilizzato per rappresentare null con valore assente. Questa classe ha vari metodi di utilità per facilitare il codice a gestire i valori come disponibili o non disponibili invece di controllare i valori nulli.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.base.Optional<T> classe -

@GwtCompatible(serializable = true)
public abstract class Optional<T>
   extends Object
      implements Serializable

Metodi di classe

Suor n Metodo e descrizione
1

static <T> Optional<T> absent()

Restituisce un'istanza facoltativa senza riferimento contenuto.

2

abstract Set<T> asSet()

Restituisce un set singleton immutabile il cui unico elemento è l'istanza contenuta, se presente; un insieme immutabile vuoto altrimenti.

3

abstract boolean equals(Object object)

Restituisce true se object è un'istanza facoltativa e i riferimenti contenuti sono uguali tra loro o entrambi sono assenti.

4

static <T> Optional<T> fromNullable(T nullableReference)

Se nullableReference è diverso da null, restituisce un'istanza facoltativa contenente tale riferimento; altrimenti restituisce absent ().

5

abstract T get()

Restituisce l'istanza contenuta, che deve essere presente.

6

abstract int hashCode()

Restituisce un codice hash per questa istanza.

7

abstract boolean isPresent()

Restituisce vero se questo contenitore contiene un'istanza (non nulla).

8

static <T> Optional<T> of(T reference)

Restituisce un'istanza facoltativa contenente il riferimento non nullo specificato.

9

abstract Optional<T> or(Optional<? extends T> secondChoice)

Restituisce questo Opzionale se ha un valore presente; secondChoice altrimenti.

10

abstract T or(Supplier<? extends T> supplier)

Restituisce l'istanza contenuta se è presente; fornitore.get () altrimenti.

11

abstract T or(T defaultValue)

Restituisce l'istanza contenuta se è presente; defaultValue altrimenti.

12

abstract T orNull()

Restituisce l'istanza contenuta se è presente; altrimenti nullo.

13

static <T> Iterable<T> presentInstances(Iterable<? extends Optional<? extends T>> optionals)

Restituisce il valore di ogni istanza presente dagli optionals forniti, in ordine, saltando le occorrenze di absent ().

14

abstract String toString()

Restituisce una rappresentazione di stringa per questa istanza.

15

abstract <V> Optional<V> transform(Function<? super T,V> function)

Se l'istanza è presente, viene trasformata con la Funzione data; in caso contrario, viene restituito absent ().

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe opzionale

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import com.google.common.base.Optional;

public class GuavaTester {
   public static void main(String args[]) {
      GuavaTester guavaTester = new GuavaTester();

      Integer value1 =  null;
      Integer value2 =  new Integer(10);
      
      //Optional.fromNullable - allows passed parameter to be null.
      Optional<Integer> a = Optional.fromNullable(value1);
      
      //Optional.of - throws NullPointerException if passed parameter is null
      Optional<Integer> b = Optional.of(value2);		

      System.out.println(guavaTester.sum(a,b));
   }

   public Integer sum(Optional<Integer> a, Optional<Integer> b) {
      //Optional.isPresent - checks the value is present or not
      System.out.println("First parameter is present: " + a.isPresent());

      System.out.println("Second parameter is present: " + b.isPresent());

      //Optional.or - returns the value if present otherwise returns
      //the default value passed.
      Integer value1 = a.or(new Integer(0));	

      //Optional.get - gets the value, value should be present
      Integer value2 = b.get();

      return value1 + value2;
   }	
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

First parameter is present: false
Second parameter is present: true
10

Le precondizioni forniscono metodi statici per verificare che un metodo o un costruttore venga richiamato con il parametro appropriato o meno. Controlla le pre-condizioni. I suoi metodi generano IllegalArgumentException in caso di errore.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.base.Preconditions classe -

@GwtCompatible
public final class Preconditions
   extends Object

Metodi di classe

Suor n Metodo e descrizione
1

static void checkArgument(boolean expression)

Assicura la veridicità di un'espressione che coinvolge uno o più parametri per il metodo chiamante.

2

static void checkArgument(boolean expression, Object errorMessage)

Assicura la veridicità di un'espressione che coinvolge uno o più parametri per il metodo chiamante.

3

static void checkArgument(boolean expression, String errorMessageTemplate, Object. errorMessageArgs)

Assicura la veridicità di un'espressione che coinvolge uno o più parametri per il metodo chiamante.

4

static int checkElementIndex(int index, int size)

Assicura che index specifichi un elemento valido in un array, in un elenco o in una stringa di dimensioni.

5

static int checkElementIndex(int index, int size, String desc)

Assicura che index specifichi un elemento valido in un array, in un elenco o in una stringa di dimensioni.

6

static <T> T checkNotNull(T reference)

Assicura che un riferimento a un oggetto passato come parametro al metodo chiamante non sia nullo.

7

static <T> T checkNotNull(T reference, Object errorMessage)

Assicura che un riferimento a un oggetto passato come parametro al metodo chiamante non sia nullo.

8

static <T> T checkNotNull(T reference, String errorMessageTemplate, Object... errorMessageArgs)

Assicura che un riferimento a un oggetto passato come parametro al metodo chiamante non sia nullo.

9

static int checkPositionIndex(int index, int size)

Assicura che index specifichi una posizione valida in un array, in un elenco o in una stringa di dimensioni.

10

static int checkPositionIndex(int index, int size, String desc)

Assicura che index specifichi una posizione valida in un array, in un elenco o in una stringa di dimensioni.

11

static void checkPositionIndexes(int start, int end, int size)

Assicura che inizio e fine specifichino posizioni valide in un array, in un elenco o in una stringa di dimensioni e siano in ordine.

12

static void checkState(boolean expression)

Assicura la verità di un'espressione che coinvolge lo stato dell'istanza chiamante, ma non coinvolge alcun parametro per il metodo chiamante.

13

static void checkState(boolean expression, Object errorMessage)

Assicura la verità di un'espressione che coinvolge lo stato dell'istanza chiamante, ma non coinvolge alcun parametro per il metodo chiamante.

14

static void checkState(boolean expression, String errorMessageTemplate, Object... errorMessageArgs)

Assicura la verità di un'espressione che coinvolge lo stato dell'istanza chiamante, ma non coinvolge alcun parametro per il metodo chiamante.

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe delle precondizioni

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import com.google.common.base.Preconditions;

public class GuavaTester {

   public static void main(String args[]) {
      GuavaTester guavaTester = new GuavaTester();

      try {
         System.out.println(guavaTester.sqrt(-3.0));
      } catch(IllegalArgumentException e) {
         System.out.println(e.getMessage());
      }

      try {
         System.out.println(guavaTester.sum(null,3));
      } catch(NullPointerException e) {
         System.out.println(e.getMessage());
      }

      try {
         System.out.println(guavaTester.getValue(6));
      } catch(IndexOutOfBoundsException e) {
         System.out.println(e.getMessage());
      }
   }

   public double sqrt(double input) throws IllegalArgumentException {
      Preconditions.checkArgument(input > 0.0,
         "Illegal Argument passed: Negative value %s.", input);
      return Math.sqrt(input);
   }

   public int sum(Integer a, Integer b) {
      a = Preconditions.checkNotNull(a, "Illegal Argument passed: First parameter is Null.");
      b = Preconditions.checkNotNull(b, "Illegal Argument passed: Second parameter is Null.");

      return a+b;
   }

   public int getValue(int input) {
      int[] data = {1,2,3,4,5};
      Preconditions.checkElementIndex(input,data.length, "Illegal Argument passed: Invalid index.");
      return 0;
   }
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

Illegal Argument passed: Negative value -3.0.
Illegal Argument passed: First parameter is Null.
Illegal Argument passed: Invalid index. (6) must be less than size (5)

L'ordine può essere visto come un comparatore arricchito con funzionalità di concatenamento migliorate, metodi di utilità multipli, capacità di ordinamento multi-tipo, ecc.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.collect.Ordering<T> classe -

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

Metodi di classe

Suor n Metodo e descrizione
1

static Ordering<Object> allEqual()

Restituisce un ordine che considera tutti i valori uguali, indicando "nessun ordine". Il passaggio di questo ordinamento a qualsiasi algoritmo di ordinamento stabile non comporta alcuna modifica all'ordine degli elementi.

2

static Ordering<Object> arbitrary()

Restituisce un ordinamento arbitrario su tutti gli oggetti, per il quale compare (a, b) == 0 implica a == b (uguaglianza di identità).

3

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

Cerca la chiave in SortList utilizzando l'algoritmo di ricerca binaria.

4

abstract int compare(T left, T right)

Confronta i suoi due argomenti per l'ordine.

5

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

Restituisce un ordinamento che prima usa l'ordinamento this, ma che in caso di "pareggio", delega poi a secondaryComparator.

6

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

Restituisce un ordinamento che prova ogni dato comparatore in ordine finché non viene trovato un risultato diverso da zero, restituendo quel risultato e restituendo zero solo se tutti i comparatori restituiscono zero.

7

static <T> Ordering<T> explicit(List<T> valuesInOrder)

Restituisce un ordine che confronta gli oggetti in base all'ordine in cui appaiono nell'elenco fornito.

8

static <T> Ordering<T> explicit(T leastValue, T... remainingValuesInOrder)

Restituisce un ordinamento che confronta gli oggetti in base all'ordine in cui sono assegnati a questo metodo.

9

static <T> Ordering<T> from(Comparator<T> comparator)

Restituisce un ordine basato su un'istanza di confronto esistente.

10

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

Restituisce i k elementi maggiori dell'iterabile dato in base a questo ordine, in ordine dal maggiore al minimo.

11

<E extends T> List<E> greatestOf(Iterator<E> iterator, int k)

Restituisce i k elementi più grandi dall'iteratore dato in base a questo ordine, in ordine dal maggiore al minimo.

12

<E extends T> ImmutableList<E> immutableSortedCopy(Iterable<E> elements)

Restituisce un elenco immutabile contenente elementi ordinati in base a questo ordine.

13

boolean isOrdered(Iterable<? extends T> iterable)

Restituisce vero se ogni elemento in iterabile dopo il primo è maggiore o uguale all'elemento che lo ha preceduto, secondo questo ordine.

14

boolean isStrictlyOrdered(Iterable<? extends T> iterable)

Restituisce vero se ogni elemento in iterabile dopo il primo è strettamente maggiore dell'elemento che lo ha preceduto, secondo questo ordinamento

15

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

Restituisce i k elementi minimi dell'iterabile dato in base a questo ordine, in ordine dal minimo al maggiore.

16

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

Restituisce i k elementi minimi dell'iteratore dato in base a questo ordine, dal minimo al massimo.

17

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

Restituisce un nuovo ordinamento che ordina gli iterabili confrontando gli elementi corrispondenti a coppie finché non viene trovato un risultato diverso da zero; impone "l'ordine del dizionario".

18

<E extends T> E max(E a, E b)

Restituisce il maggiore dei due valori in base a questo ordine.

19

<E extends T> E max(E a, E b, E c, E... rest)

Restituisce il massimo dei valori specificati in base a questo ordine.

20

<E extends T> E max(Iterable<E> iterable)

Restituisce il massimo dei valori specificati in base a questo ordine.

21

<E extends T> E max(Iterator<E> iterator)

Restituisce il massimo dei valori specificati in base a questo ordine.

22

<E extends T> E min(E a, E b)

Restituisce il minore dei due valori in base a questo ordine.

23

<E extends T> E min(E a, E b, E c, E... rest)

Restituisce il minimo dei valori specificati in base a questo ordine.

24

<E extends T> E min(Iterable<E> iterable)

Restituisce il minimo dei valori specificati in base a questo ordine.

25

<E extends T> E min(Iterator<E> iterator)

Restituisce il minimo dei valori specificati in base a questo ordine.

26

static <C extends Comparable> Ordering<C> natural()

Restituisce un ordinamento serializzabile che utilizza l'ordine naturale dei valori.

27

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

Restituisce un ordinamento che considera null come inferiore a tutti gli altri valori e lo utilizza per confrontare valori non null.

28

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

Restituisce un ordine che considera null come maggiore di tutti gli altri valori e utilizza questo ordinamento per confrontare valori non null.

29

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

Restituisce un nuovo ordinamento su F che ordina gli elementi applicando prima una funzione ad essi, quindi confrontando i risultati usando questo.

30

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

Restituisce il contrario di questo ordine; Ordering equivalente a Collections.reverseOrder (Comparator).

31

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

Restituisce un elenco modificabile contenente elementi ordinati in base a questo ordine; usalo solo quando l'elenco risultante potrebbe richiedere ulteriori modifiche o potrebbe contenere null.

32

static Ordering<Object> usingToString()

Restituisce un ordinamento che confronta gli oggetti in base all'ordinamento naturale delle loro rappresentazioni di stringa come restituito da toString ().

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe di ordinazione

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo 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);
   }
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

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]

La classe Objects fornisce funzioni di supporto applicabili a tutti gli oggetti come uguale, hashCode, ecc.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.base.Objects classe -

@GwtCompatible
public final class Objects
   extends Object

Metodi di classe

Suor n Metodo e descrizione
1

static boolean equal(Object a, Object b)

Determina se due oggetti possibilmente nulli sono uguali.

2

static <T> T firstNonNull(T first, T second)

Deprecato. Utilizza invece MoreObjects.firstNonNull (T, T). La rimozione di questo metodo è prevista per giugno 2016.

3

static int hashCode(Object... objects)

Genera un codice hash per più valori.

4

static Objects.ToStringHelper toStringHelper(Class<?> clazz)

Deprecato. Utilizza invece MoreObjects.toStringHelper (Class). La rimozione di questo metodo è prevista per giugno 2016

5

static Objects.ToStringHelper toStringHelper(Object self)

Deprecato. Utilizza invece MoreObjects.toStringHelper (Object). La rimozione di questo metodo è prevista per giugno 2016.

6

static Objects.ToStringHelper toStringHelper(String className)

Deprecato. Utilizza invece MoreObjects.toStringHelper (String). La rimozione di questo metodo è prevista per giugno 2016.

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe di oggetti

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import com.google.common.base.Objects;

public class GuavaTester {
   public static void main(String args[]) {
      Student s1 = new Student("Mahesh", "Parashar", 1, "VI");	
      Student s2 = new Student("Suresh", null, 3, null);	
	  
      System.out.println(s1.equals(s2));
      System.out.println(s1.hashCode());	
      System.out.println(
         Objects.toStringHelper(s1)
         .add("Name",s1.getFirstName()+" " + s1.getLastName())
         .add("Class", s1.getClassName())
         .add("Roll No", s1.getRollNo())
         .toString());
   }
}

class Student {
   private String firstName;
   private String lastName;
   private int rollNo;
   private String className;

   public Student(String firstName, String lastName, int rollNo, String className) {
      this.firstName = firstName;
      this.lastName = lastName;
      this.rollNo = rollNo;
      this.className = className;		
   }

   @Override
   public boolean equals(Object object) {
      if(!(object instanceof Student) || object == null) {
         return false;
      }
      Student student = (Student)object;
      // no need to handle null here		
      // Objects.equal("test", "test") == true
      // Objects.equal("test", null) == false
      // Objects.equal(null, "test") == false
      // Objects.equal(null, null) == true		
      return Objects.equal(firstName, student.firstName)  // first name can be null
         && Objects.equal(lastName, student.lastName)     // last name can be null
         && Objects.equal(rollNo, student.rollNo)	
         && Objects.equal(className, student.className);  // class name can be null
   }

   @Override
   public int hashCode() {
      //no need to compute hashCode by self
      return Objects.hashCode(className,rollNo);
   }
   
   public String getFirstName() {
      return firstName;
   }
   
   public void setFirstName(String firstName) {
      this.firstName = firstName;
   }
   
   public String getLastName() {
      return lastName;
   }
   
   public void setLastName(String lastName) {
      this.lastName = lastName;
   }
   
   public int getRollNo() {
      return rollNo;
   }
   
   public void setRollNo(int rollNo) {
      this.rollNo = rollNo;
   }
   
   public String getClassName() {
      return className;
   }
   
   public void setClassName(String className) {
      this.className = className;
   }
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

false
85871
Student{Name=Mahesh Parashar, Class=VI, Roll No=1}

L'intervallo rappresenta un intervallo o una sequenza. Viene utilizzato per ottenere un insieme di numeri / stringhe che si trovano in un intervallo particolare.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.collect.Range<C> classe -

@GwtCompatible
public final class Range<C extends Comparable>
   extends Object
      implements Predicate<C>, Serializable

Metodi

Suor n Metodo e descrizione
1

static <C extends Comparable<?>> Range<C> all()

Restituisce un intervallo che contiene ogni valore di tipo C.

2

boolean apply(C input)Deprecated.

Fornito solo per soddisfare l'interfaccia Predicate; usa invece contiene (C).

3

static <C extends Comparable<?>> Range<C> atLeast(C endpoint)

Restituisce un intervallo che contiene tutti i valori maggiori o uguali all'endpoint.

4

static <C extends Comparable<?>> Range<C> atMost(C endpoint)

Restituisce un intervallo che contiene tutti i valori minori o uguali all'endpoint.

5

Range<C> canonical(DiscreteDomain<C> domain)

Restituisce la forma canonica di questo intervallo nel dominio specificato.

6

static <C extends Comparable<?>> Range<C> closed(C lower, C upper)

Restituisce un intervallo che contiene tutti i valori maggiori o uguali a minore e minore o uguale a superiore.

7

static <C extends Comparable<?>> Range<C> closedOpen(C lower, C upper)

Restituisce un intervallo che contiene tutti i valori maggiori o uguali a inferiore e rigorosamente inferiori a superiore.

8

boolean contains(C value)

Restituisce vero se il valore rientra nei limiti di questo intervallo.

9

boolean containsAll(Iterable<? extends C> values)

Restituisce vero se ogni elemento in values ​​è contenuto in questo intervallo.

10

static <C extends Comparable<?>> Range<C> downTo(C endpoint, BoundType boundType)

Restituisce un intervallo dall'endpoint specificato, che può essere inclusivo (chiuso) o esclusivo (aperto), senza limite superiore.

11

static <C extends Comparable<?>> Range<C> encloseAll(Iterable<C> values)

Restituisce l'intervallo minimo che contiene tutti i valori dati.

12

boolean encloses(Range<C> other)

Restituisce vero se i limiti di altro non si estendono al di fuori dei limiti di questo intervallo.

13

boolean equals(Object object)

Restituisce vero se l'oggetto è un intervallo con gli stessi endpoint e tipi associati di questo intervallo.

14

static <C extends Comparable<?>> Range<C> greaterThan(C endpoint)

Restituisce un intervallo che contiene tutti i valori strettamente maggiori dell'endpoint.

15

int hashCode()

Restituisce un codice hash per questo intervallo.

16

boolean hasLowerBound()

Restituisce vero se questo intervallo ha un endpoint inferiore.

17

boolean hasUpperBound()

Restituisce vero se questo intervallo ha un endpoint superiore.

18

Range<C> intersection(Range<C> connectedRange)

Restituisce l'intervallo massimo racchiuso da questo intervallo e da connectedRange, se tale intervallo esiste.

19

boolean isConnected(Range<C> other)

Restituisce vero se esiste un intervallo (possibilmente vuoto) racchiuso sia da questo intervallo che da altri.

20

boolean isEmpty()

Restituisce vero se questo intervallo è nella forma [v..v) o (v..v].

21

static <C extends Comparable<?>> Range<C> lessThan(C endpoint)

Restituisce un intervallo che contiene tutti i valori strettamente inferiori a endpoint.

22

BoundType lowerBoundType()

Restituisce il tipo del limite inferiore di questo intervallo: BoundType.CLOSED se l'intervallo include il suo punto finale inferiore, BoundType.OPEN in caso contrario.

23

C lowerEndpoint()

Restituisce il punto finale inferiore di questo intervallo.

24

static <C extends Comparable<?>> Range<C> open(C lower, C upper)

Restituisce un intervallo che contiene tutti i valori strettamente maggiori di lower e rigorosamente minori di upper.

25

static <C extends Comparable<?>> Range<C> openClosed(C lower, C upper)

Restituisce un intervallo che contiene tutti i valori rigorosamente maggiori di inferiore e minore o uguale a superiore.

26

static <C extends Comparable<?>> Range<C> range(C lower, BoundType lowerType, C upper, BoundType upperType)

Restituisce un intervallo che contiene qualsiasi valore da inferiore a superiore, dove ogni endpoint può essere inclusivo (chiuso) o esclusivo (aperto).

27

static <C extends Comparable<?>> Range<C> singleton(C value)

Restituisce un intervallo che contiene solo il valore specificato.

28

Range<C> span(Range<C> other)

Restituisce l'intervallo minimo che racchiude sia questo intervallo che l'altro.

29

String toString()

Restituisce una rappresentazione di stringa di questo intervallo, come "[3..5)" (altri esempi sono elencati nella documentazione della classe).

30

BoundType upperBoundType()

Restituisce il tipo del limite superiore di questo intervallo: BoundType.CLOSED se l'intervallo include il suo punto finale superiore, BoundType.OPEN in caso contrario.

31

C upperEndpoint()

Restituisce il punto finale superiore di questo intervallo.

32

static <C extends Comparable<?>> Range<C> upTo(C endpoint, BoundType boundType)

Restituisce un intervallo senza limite inferiore fino all'endpoint specificato, che può essere inclusivo (chiuso) o esclusivo (aperto).

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe di intervallo

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import com.google.common.collect.ContiguousSet;
import com.google.common.collect.DiscreteDomain;
import com.google.common.collect.Range;
import com.google.common.primitives.Ints;

public class GuavaTester {

   public static void main(String args[]) {
      GuavaTester tester = new GuavaTester();
      tester.testRange();
   }

   private void testRange() {

      //create a range [a,b] = { x | a <= x <= b}
      Range<Integer> range1 = Range.closed(0, 9);	
      System.out.print("[0,9] : ");
      printRange(range1);		
      
      System.out.println("5 is present: " + range1.contains(5));
      System.out.println("(1,2,3) is present: " + range1.containsAll(Ints.asList(1, 2, 3)));
      System.out.println("Lower Bound: " + range1.lowerEndpoint());
      System.out.println("Upper Bound: " + range1.upperEndpoint());

      //create a range (a,b) = { x | a < x < b}
      Range<Integer> range2 = Range.open(0, 9);
      System.out.print("(0,9) : ");
      printRange(range2);

      //create a range (a,b] = { x | a < x <= b}
      Range<Integer> range3 = Range.openClosed(0, 9);
      System.out.print("(0,9] : ");
      printRange(range3);

      //create a range [a,b) = { x | a <= x < b}
      Range<Integer> range4 = Range.closedOpen(0, 9);
      System.out.print("[0,9) : ");
      printRange(range4);

      //create an open ended range (9, infinity
      Range<Integer> range5 = Range.greaterThan(9);
      System.out.println("(9,infinity) : ");
      System.out.println("Lower Bound: " + range5.lowerEndpoint());
      System.out.println("Upper Bound present: " + range5.hasUpperBound());

      Range<Integer> range6 = Range.closed(3, 5);	
      printRange(range6);

      //check a subrange [3,5] in [0,9]
      System.out.println("[0,9] encloses [3,5]:" + range1.encloses(range6));

      Range<Integer> range7 = Range.closed(9, 20);	
      printRange(range7);
      
      //check ranges to be connected		
      System.out.println("[0,9] is connected [9,20]:" + range1.isConnected(range7));
      Range<Integer> range8 = Range.closed(5, 15);	

      //intersection
      printRange(range1.intersection(range8));

      //span
      printRange(range1.span(range8));
   }

   private void printRange(Range<Integer> range) {		
   
      System.out.print("[ ");
      
      for(int grade : ContiguousSet.create(range, DiscreteDomain.integers())) {
         System.out.print(grade +" ");
      }
      System.out.println("]");
   }
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

[0,9] : [ 0 1 2 3 4 5 6 7 8 9 ]
5 is present: true
(1,2,3) is present: true
Lower Bound: 0
Upper Bound: 9
(0,9) : [ 1 2 3 4 5 6 7 8 ]
(0,9] : [ 1 2 3 4 5 6 7 8 9 ]
[0,9) : [ 0 1 2 3 4 5 6 7 8 ]
(9,infinity) : 
Lower Bound: 9
Upper Bound present: false
[ 3 4 5 ]
[0,9] encloses [3,5]:true
[ 9 10 11 12 13 14 15 16 17 18 19 20 ]
[0,9] is connected [9,20]:true
[ 5 6 7 8 9 ]
[ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ]

La classe Throwables fornisce metodi di utilità relativi all'interfaccia Throwable.

Dichiarazione di classe

Di seguito è riportata la dichiarazione per com.google.common.base.Throwables classe -

public final class Throwables
   extends Object

Metodi di classe

Suor n Metodo e descrizione
1

static List<Throwable> getCausalChain(Throwable throwable)

Ottiene una catena di cause lanciabili come elenco.

2

static Throwable getRootCause(Throwable throwable)

Restituisce la causa più intima di throwable.

3

static String getStackTraceAsString(Throwable throwable)

Restituisce una stringa contenente il risultato di toString (), seguita dall'analisi dello stack ricorsiva completa di throwable.

4

static RuntimeException propagate(Throwable throwable)

Propaga lanciabile così com'è se si tratta di un'istanza di RuntimeException o Error, oppure come ultima risorsa, lo avvolge in una RuntimeException quindi si propaga.

5

static <X extends Throwable> void propagateIfInstanceOf(Throwable throwable, Class<X> declaredType)

Propaga throwable esattamente così com'è, se e solo se è un'istanza di DeclarType.

6

static void propagateIfPossible(Throwable throwable)

Propaga throwable esattamente così com'è, se e solo se è un'istanza di RuntimeException o Error.

7

static <X extends Throwable> void propagateIfPossible(Throwable throwable, Class<X> declaredType)

Propaga throwable esattamente così com'è, se e solo se è un'istanza di RuntimeException, Error o DeclarType.

8

static <X1 extends Throwable,X2 extends Throwable>void propagateIfPossible(Throwable throwable, Class<X1> declaredType1, Class<X2> declaredType2)

Propaga throwable esattamente così com'è, se e solo se è un'istanza di RuntimeException, Error, DeclarType1 o DeclaratedType2.

Metodi ereditati

Questa classe eredita i metodi dalla classe seguente:

  • java.lang.Object

Esempio di classe Throwables

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import java.io.IOException;

import com.google.common.base.Objects;
import com.google.common.base.Throwables;

public class GuavaTester {
   public static void main(String args[]) {
   
      GuavaTester tester = new GuavaTester();

      try {
         tester.showcaseThrowables();
         
      } catch (InvalidInputException e) {
         //get the root cause
         System.out.println(Throwables.getRootCause(e));
      
      } catch (Exception e) {
         //get the stack trace in string format
         System.out.println(Throwables.getStackTraceAsString(e));
      }

      try {
         tester.showcaseThrowables1();

      } catch (Exception e) {
         System.out.println(Throwables.getStackTraceAsString(e));
      }
   }

   public void showcaseThrowables() throws InvalidInputException {
      try {
         sqrt(-3.0);
      } catch (Throwable e) {
         //check the type of exception and throw it
         Throwables.propagateIfInstanceOf(e, InvalidInputException.class);
         Throwables.propagate(e);
      }
   }

   public void showcaseThrowables1() {
      try {
         int[] data = {1,2,3};
         getValue(data, 4);
      } catch (Throwable e) {
         Throwables.propagateIfInstanceOf(e, IndexOutOfBoundsException.class);
         Throwables.propagate(e);
      }
   }

   public double sqrt(double input) throws InvalidInputException {
      if(input < 0) throw new InvalidInputException();
      return Math.sqrt(input);
   }

   public double getValue(int[] list, int index) throws IndexOutOfBoundsException {
      return list[index];
   }

   public void dummyIO() throws IOException {
      throw new IOException();
   }
}

class InvalidInputException extends Exception {
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

InvalidInputException
java.lang.ArrayIndexOutOfBoundsException: 4
   at GuavaTester.getValue(GuavaTester.java:52)
   at GuavaTester.showcaseThrowables1(GuavaTester.java:38)
   at GuavaTester.main(GuavaTester.java:19)

Guava introduce molte raccolte avanzate basate sull'esperienza degli sviluppatori nello sviluppo di applicazioni. Di seguito è riportato un elenco di raccolte utili:

Suor n Nome e descrizione della raccolta
1 Multiset

Un'estensione dell'interfaccia Set per consentire la duplicazione di elementi.

2 Multimappa

Un'estensione dell'interfaccia Map in modo che le sue chiavi possano essere mappate su più valori alla volta.

3 BiMap

Un'estensione dell'interfaccia Map per supportare le operazioni inverse.

4 tavolo

La tabella rappresenta una mappa speciale in cui è possibile specificare due chiavi in ​​modo combinato per fare riferimento a un singolo valore.

Guava fornisce un meccanismo di cache basato sulla memoria molto potente tramite un'interfaccia LoadingCache <K, V>. I valori vengono caricati automaticamente nella cache e fornisce molti metodi di utilità utili per le esigenze di memorizzazione nella cache.

Dichiarazione di interfaccia

Di seguito è riportata la dichiarazione per com.google.common.cache.LoadingCache<K,V> interfaccia -

@Beta
@GwtCompatible
public interface LoadingCache<K,V>
   extends Cache<K,V>, Function<K,V>

Metodi di interfaccia

Suor n Metodo e descrizione
1

V apply(K key)

Deprecato. Fornito per soddisfare l'interfaccia della funzione; usa invece get (K) o getUnchecked (K).

2

ConcurrentMap<K,V> asMap()

Restituisce una visualizzazione delle voci archiviate in questa cache come mappa thread-safe.

3

V get(K key)

Restituisce il valore associato alla chiave in questa cache, caricando prima quel valore se necessario.

4

ImmutableMap<K,V> getAll(Iterable<? extends K> keys)

Restituisce una mappa dei valori associati alle chiavi, creando o recuperando quei valori se necessario.

5

V getUnchecked(K key)

Restituisce il valore associato alla chiave in questa cache, caricando prima quel valore se necessario.

6

void refresh(K key)

Carica un nuovo valore per la chiave, possibilmente in modo asincrono.

Esempio di LoadingCache

Crea il seguente programma java usando qualsiasi editor di tua scelta, diciamo C:/> Guava.

GuavaTester.java

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeUnit;

import com.google.common.base.MoreObjects;
import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader;
import com.google.common.cache.LoadingCache;

public class GuavaTester {
   public static void main(String args[]) {
   
      //create a cache for employees based on their employee id
      LoadingCache<String, Employee> employeeCache = 
         CacheBuilder.newBuilder()
         .maximumSize(100)                             // maximum 100 records can be cached
         .expireAfterAccess(30, TimeUnit.MINUTES)      // cache will expire after 30 minutes of access
         .build(new CacheLoader<String, Employee>() {  // build the cacheloader
            
            @Override
            public Employee load(String empId) throws Exception {
               //make the expensive call
               return getFromDatabase(empId);
            } 
         });

      try {			
         //on first invocation, cache will be populated with corresponding
         //employee record
         System.out.println("Invocation #1");
         System.out.println(employeeCache.get("100"));
         System.out.println(employeeCache.get("103"));
         System.out.println(employeeCache.get("110"));
         
         //second invocation, data will be returned from cache
         System.out.println("Invocation #2");
         System.out.println(employeeCache.get("100"));
         System.out.println(employeeCache.get("103"));
         System.out.println(employeeCache.get("110"));

      } catch (ExecutionException e) {
         e.printStackTrace();
      }
   }

   private static Employee getFromDatabase(String empId) {
   
      Employee e1 = new Employee("Mahesh", "Finance", "100");
      Employee e2 = new Employee("Rohan", "IT", "103");
      Employee e3 = new Employee("Sohan", "Admin", "110");

      Map<String, Employee> database = new HashMap<String, Employee>();
      
      database.put("100", e1);
      database.put("103", e2);
      database.put("110", e3);
      
      System.out.println("Database hit for" + empId);
      
      return database.get(empId);		
   }
}

class Employee {
   String name;
   String dept;
   String emplD;

   public Employee(String name, String dept, String empID) {
      this.name = name;
      this.dept = dept;
      this.emplD = empID;
   }
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }
   
   public String getDept() {
      return dept;
   }
   
   public void setDept(String dept) {
      this.dept = dept;
   }
   
   public String getEmplD() {
      return emplD;
   }
   
   public void setEmplD(String emplD) {
      this.emplD = emplD;
   }

   @Override
   public String toString() {
      return MoreObjects.toStringHelper(Employee.class)
      .add("Name", name)
      .add("Department", dept)
      .add("Emp Id", emplD).toString();
   }	
}

Verifica il risultato

Compila la classe usando javac compilatore come segue -

C:\Guava>javac GuavaTester.java

Ora esegui il GuavaTester per vedere il risultato.

C:\Guava>java GuavaTester

Guarda il risultato.

Invocation #1
Database hit for100
Employee{Name=Mahesh, Department=Finance, Emp Id=100}
Database hit for103
Employee{Name=Rohan, Department=IT, Emp Id=103}
Database hit for110
Employee{Name=Sohan, Department=Admin, Emp Id=110}
Invocation #2
Employee{Name=Mahesh, Department=Finance, Emp Id=100}
Employee{Name=Rohan, Department=IT, Emp Id=103}
Employee{Name=Sohan, Department=Admin, Emp Id=110}

Guava introduce molte utilità di stringa avanzate basate sull'esperienza degli sviluppatori nello sviluppo di applicazioni. Di seguito è riportato l'elenco di utili utilità basate su stringhe:

Suor n Nome e descrizione dell'utilità
1 Falegname

Utilità per unire oggetti, stringhe ecc.

2 Splitter

Utilità per dividere la stringa.

3 CharMatcher

Utilità per le operazioni sui personaggi.

4 CaseFormat

Utilità per modificare i formati delle stringhe.

Poiché i tipi primitivi di Java non possono essere utilizzati per passare generici o raccolte come input, Guava ha fornito molte classi di Wrapper Utilities per gestire i tipi primitivi come oggetti. Di seguito è riportato l'elenco di utili utilità di elaborazione primitiva:

Suor n Nome e descrizione dell'utilità
1 Byte

Utilità per byte primitivi.

2 Pantaloncini

Utilità per breve primitivo.

3 Ints

Utilità per primitive int.

4 Longs

Utilità per primitivo lungo.

5 Galleggianti

Utilità per float primitivo.

6 Doppio

Utilità per il doppio primitivo.

7 Chars

Utilità per il carattere primitivo.

8 Booleani

Utilità per booleano primitivo.

Guava fornisce classi di utilità relative alla matematica per gestire int, long e BigInteger. Di seguito è riportato l'elenco delle utilità utili:

Suor n Nome e descrizione dell'utilità
1 IntMath

Utilità matematica per int.

2 LongMath

Utilità matematica a lungo.

3 BigIntegerMath

Utilità matematica per BigInteger.