Questo articolo è stato tradotto automaticamente. Per visualizzare l'articolo in inglese, selezionare la casella di controllo Inglese. È possibile anche visualizzare il testo inglese in una finestra popup posizionando il puntatore del mouse sopra il testo.
Traduzione
Inglese

Metodo Enumerable.SingleOrDefault<TSource>(IEnumerable<TSource>)

 

Restituisce il singolo elemento di una sequenza o un valore predefinito se la sequenza è vuota; questo metodo genera un'eccezione se esiste più di un elemento nella sequenza.

Spazio dei nomi:   System.Linq
Assembly:  System.Core (in System.Core.dll)

public static TSource SingleOrDefault<TSource>(
	this IEnumerable<TSource> source
)

Parametri

source

Oggetto IEnumerable<T> di cui restituire il singolo elemento.

Valore restituito

Type: TSource

Il singolo elemento della sequenza di input, o default(TSource) se la sequenza non contiene elementi.

Parametri di tipo

TSource

Tipo degli elementi di source.

Exception Condition
ArgumentNullException

source è null.

InvalidOperationException

La sequenza di input contiene più elementi.

Il valore predefinito per i tipi di riferimento e i tipi che ammettono valori Null è null.

Il metodo SingleOrDefault non consente di specificare un valore predefinito.Se si desidera specificare un valore predefinito diverso da default(TSource), utilizzare il metodo DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) come descritto nella sezione Esempio.

Nell'esempio di codice seguente viene illustrato come utilizzare l'oggetto SingleOrDefault<TSource>(IEnumerable<TSource>) per selezionare il singolo elemento di una matrice.

string[] fruits1 = { "orange" };

string fruit1 = fruits1.SingleOrDefault();

Console.WriteLine(fruit1);

/*
 This code produces the following output:

 orange
*/

Nell'esempio di codice riportato di seguito viene dimostrato che SingleOrDefault<TSource>(IEnumerable<TSource>) restituisce un valore predefinito quando la sequenza non contiene esattamente un elemento.

string[] fruits2 = { };

string fruit2 = fruits2.SingleOrDefault();

Console.WriteLine(
    String.IsNullOrEmpty(fruit2) ? "No such string!" : fruit2);

/*
 This code produces the following output:

 No such string!
*/

Talvolta il valore di default(TSource) non è il valore predefinito che si desidera utilizzare se la raccolta non contiene elementi.Anziché verificare il risultato del valore predefinito non desiderato e quindi modificarlo se necessario, è possibile utilizzare il metodo DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) per specificare il valore predefinito che si desidera utilizzare se la raccolta è vuota.Chiamare quindi il metodo Single<TSource>(IEnumerable<TSource>) per ottenere l'elemento.Nell'esempio di codice seguente vengono utilizzate entrambe le tecniche per ottenere 1 come valore predefinito se una raccolta di numeri di pagine è vuoto.Poiché il valore predefinito per un numero intero è 0, valore che non è in genere valido per un numero di pagina, è necessario specificare 1 come valore predefinito.Una volta terminata l'esecuzione della query, viene verificato se nella prima variabile del risultato è presente il valore predefinito non desiderato.La seconda variabile del risultato viene ottenuta chiamando DefaultIfEmpty<TSource>(IEnumerable<TSource>, TSource) per specificare un valore predefinito di 1.

int[] pageNumbers = { };

// Setting the default value to 1 after the query.
int pageNumber1 = pageNumbers.SingleOrDefault();
if (pageNumber1 == 0)
{
    pageNumber1 = 1;
}
Console.WriteLine("The value of the pageNumber1 variable is {0}", pageNumber1);

// Setting the default value to 1 by using DefaultIfEmpty() in the query.
int pageNumber2 = pageNumbers.DefaultIfEmpty(1).Single();
Console.WriteLine("The value of the pageNumber2 variable is {0}", pageNumber2);

/*
 This code produces the following output:

 The value of the pageNumber1 variable is 1
 The value of the pageNumber2 variable is 1
*/

Universal Windows Platform
Disponibile da 4.5
.NET Framework
Disponibile da 3.5
Portable Class Library
Supportato in: portable .NET platforms
Silverlight
Disponibile da 2.0
Windows Phone Silverlight
Disponibile da 7.0
Windows Phone
Disponibile da 8.1
Torna all'inizio
Mostra: