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 Queryable.Aggregate<TSource>(IQueryable<TSource>, Expression<Func<TSource, TSource, TSource>>)

 

Data di pubblicazione: ottobre 2016

Applica una funzione accumulatore una sequenza.

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

public static TSource Aggregate<TSource>(
	this IQueryable<TSource> source,
	Expression<Func<TSource, TSource, TSource>> func
)

Parametri

source
Type: System.Linq.IQueryable<TSource>

Una sequenza su cui aggregare.

func
Type: System.Linq.Expressions.Expression<Func<TSource, TSource, TSource>>

Funzione accumulatore da applicare a ogni elemento.

Valore restituito

Type: TSource

Valore finale dell'accumulatore.

Parametri tipo

TSource

Tipo degli elementi di source.

Exception Condition
ArgumentNullException

source o func è null.

InvalidOperationException

source non contiene elementi.

Questo metodo contiene almeno un parametro di tipo Expression<TDelegate> il cui argomento di tipo è uno del Func<T, TResult> tipi. Per questi parametri, è possibile passare un'espressione lambda e verrà compilato in un Expression<TDelegate>.

Il Aggregate<TSource>(IQueryable<TSource>, Expression<Func<TSource, TSource, TSource>>) metodo genera un MethodCallExpression che rappresenta una chiamata Aggregate<TSource>(IQueryable<TSource>, Expression<Func<TSource, TSource, TSource>>) stesso come un metodo generico costruito. Passa quindi il MethodCallExpression per il Execute<TResult>(Expression) metodo il IQueryProvider rappresentato dal Provider proprietà del source parametro.

Il comportamento della query che si verifica in seguito all'esecuzione di una struttura ad albero dell'espressione che rappresenta una chiamata Aggregate<TSource>(IQueryable<TSource>, Expression<Func<TSource, TSource, TSource>>) dipende dall'implementazione del tipo di source parametro. Il comportamento previsto è che la funzione specificata, func, viene applicato a ogni valore nella sequenza di origine e di accumulato viene restituito. Il primo valore in source viene utilizzato come valore di inizializzazione per il valore accumulato, che corrisponde al primo parametro in func.

Per semplificare le comuni operazioni di aggregazione, il set di operatori di query standard include anche due metodi di conteggio, Count<TSource> e LongCount<TSource>, e quattro i metodi di aggregazione numerica, vale a dire Max<TSource>, Min<TSource>, Sum, e Average.

Esempio di codice seguente viene illustrato come utilizzare Aggregate<TSource>(IQueryable<TSource>, Expression<Func<TSource, TSource, TSource>>) per compilare una frase da una matrice di stringhe.

string sentence = "the quick brown fox jumps over the lazy dog";

// Split the string into individual words.
string[] words = sentence.Split(' ');

// Use Aggregate() to prepend each word to the beginning of the 
// new sentence to reverse the word order.
string reversed =
    words.AsQueryable().Aggregate(
    (workingSentence, next) => next + " " + workingSentence
    );

Console.WriteLine(reversed);

// This code produces the following output:
//
// dog lazy the over jumps fox brown quick the 

Universal Windows Platform
Disponibile da 8
.NET Framework
Disponibile da 3.5
Libreria di classi portabile
Supportato in: piattaforme .NET portabili
Silverlight
Disponibile da 2.0
Windows Phone Silverlight
Disponibile da 7.1
Windows Phone
Disponibile da 8.1
Torna all'inizio
Mostra: