Dieser Artikel wurde maschinell übersetzt. Wenn Sie die englische Version des Artikels anzeigen möchten, aktivieren Sie das Kontrollkästchen Englisch. Sie können den englischen Text auch in einem Popupfenster anzeigen, indem Sie den Mauszeiger über den Text bewegen.
Übersetzung
Englisch

Queryable.LastOrDefault<TSource>-Methode: (IQueryable<TSource>)

 

Veröffentlicht: Oktober 2016

Gibt das letzte Element in einer Sequenz oder einen Standardwert zurück, wenn die Sequenz keine Elemente enthält.

Namespace:   System.Linq
Assembly:  System.Core (in System.Core.dll)

public static TSource LastOrDefault<TSource>(
	this IQueryable<TSource> source
)

Parameter

source
Type: System.Linq.IQueryable<TSource>

Ein IQueryable<T> das letzte Element zurückgegeben.

Rückgabewert

Type: TSource

default(TSource) Wenn source leer ist, andernfalls das letzte Element im source.

Typparameter

TSource

Der Typ der Elemente von source.

Exception Condition
ArgumentNullException

source ist null.

Die LastOrDefault<TSource>(IQueryable<TSource>) -Methode generiert eine MethodCallExpression Aufruf darstellt LastOrDefault<TSource>(IQueryable<TSource>) sich selbst als konstruierte generische Methode. Anschließend übergibt der MethodCallExpression zu der Execute<TResult>(Expression) Methode der IQueryProvider durch dargestellt die Provider Eigenschaft der source Parameter.

Das Abfrageverhalten durch das Ausführen einer Ausdrucksbaumstruktur, die aufrufende darstellt, LastOrDefault<TSource>(IQueryable<TSource>) hängt von der Implementierung des Typs der source Parameter. Das erwartete Verhalten ist, wird das letzte Element im source, oder ein Standardwert, wenn source ist leer.

Die LastOrDefault Methode bietet keine Möglichkeit, einen Standardwert anzugeben. Wenn Sie als einen Standardwert angeben möchten default(TSource), verwenden Sie die DefaultIfEmpty<TSource>(IQueryable<TSource>, TSource) Methode, wie im Beispielabschnitt beschrieben.

Im folgenden Codebeispiel wird veranschaulicht, wie Sie LastOrDefault<TSource>(IQueryable<TSource>) für ein leeres Array.

// Create an empty array.
string[] fruits = { };

// Get the last item in the array, or else the default
// value for type string (null).
string last = fruits.AsQueryable().LastOrDefault();

Console.WriteLine(
    String.IsNullOrEmpty(last) ? "[STRING IS NULL OR EMPTY]" : last);

/*
    This code produces the following output:

    [STRING IS NULL OR EMPTY]
*/

Der Wert von default(TSource) ist nicht der Standardwert, der zu verwenden, wenn die Auflistung keine Elemente enthält. Anstatt das Ergebnis für den unerwünschten Standardwert zu ändern, wenn erforderlich, können Sie die DefaultIfEmpty<TSource>(IQueryable<TSource>, TSource) Methode, um den Standardwert anzugeben, die zu verwenden, wenn die Auflistung leer ist. Anschließend rufen Sie Last<TSource>(IQueryable<TSource>) auf das letzte Element abzurufen. Im folgenden Codebeispiel werden beide Verfahren verwendet, um den Standardwert 1 zu erhalten, wenn eine Auflistung der numerischen Tage des Monats leer ist. Da der Standardwert für eine ganze Zahl 0 nicht zu einem beliebigen Tag des Monats entspricht ist, muss der Standardwert stattdessen als 1 angegeben werden. Die erste Ergebnisvariable wird auf den unerwünschten Standardwert überprüft, nachdem die Abfrage abgeschlossen ist. Die zweite Ergebnisvariable wird durch Aufrufen von DefaultIfEmpty<TSource>(IQueryable<TSource>, TSource) an den Standardwert 1.

List<int> daysOfMonth = new List<int> { };

// Setting the default value to 1 after the query.
int lastDay1 = daysOfMonth.AsQueryable().LastOrDefault();
if (lastDay1 == 0)
{
    lastDay1 = 1;
}
Console.WriteLine("The value of the lastDay1 variable is {0}", lastDay1);

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

/*
 This code produces the following output:

 The value of the lastDay1 variable is 1
 The value of the lastDay2 variable is 1
*/

Universelle Windows-Plattform
Verfügbar seit 8
.NET Framework
Verfügbar seit 3.5
Portierbare Klassenbibliothek
Unterstützt in: portierbare .NET-Plattformen
Silverlight
Verfügbar seit 2.0
Windows Phone Silverlight
Verfügbar seit 7.1
Windows Phone
Verfügbar seit 8.1
Zurück zum Anfang
Anzeigen: