Guava - Classe opzionale
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