Enumerable.Sum Metoda

Definicja

Oblicza sumę sekwencji wartości liczbowych.

Przeciążenia

Sum(IEnumerable<Single>)

Oblicza sumę sekwencji Single wartości.

Sum(IEnumerable<Nullable<Int32>>)

Oblicza sumę sekwencji wartości dopuszczanych Int32 do wartości null.

Sum(IEnumerable<Nullable<Single>>)

Oblicza sumę sekwencji wartości dopuszczanych Single do wartości null.

Sum(IEnumerable<Nullable<Int64>>)

Oblicza sumę sekwencji wartości dopuszczanych Int64 do wartości null.

Sum(IEnumerable<Nullable<Double>>)

Oblicza sumę sekwencji wartości dopuszczanych Double do wartości null.

Sum(IEnumerable<Int32>)

Oblicza sumę sekwencji Int32 wartości.

Sum(IEnumerable<Int64>)

Oblicza sumę sekwencji Int64 wartości.

Sum(IEnumerable<Double>)

Oblicza sumę sekwencji Double wartości.

Sum(IEnumerable<Decimal>)

Oblicza sumę sekwencji Decimal wartości.

Sum(IEnumerable<Nullable<Decimal>>)

Oblicza sumę sekwencji wartości dopuszczanych Decimal do wartości null.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Single>)

Oblicza sumę sekwencji Single wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Int64>>)

Oblicza sumę sekwencji wartości null, które są uzyskiwane Int64 przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Int32>>)

Oblicza sumę sekwencji wartości null, które są uzyskiwane Int32 przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Double>>)

Oblicza sumę sekwencji wartości null, które są uzyskiwane Double przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Single>>)

Oblicza sumę sekwencji wartości null, które są uzyskiwane Single przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Int64>)

Oblicza sumę sekwencji Int64 wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Int32>)

Oblicza sumę sekwencji Int32 wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>)

Oblicza sumę sekwencji Double wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Decimal>)

Oblicza sumę sekwencji Decimal wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Decimal>>)

Oblicza sumę sekwencji wartości null, które są uzyskiwane Decimal przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

Sum(IEnumerable<Single>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Single wartości.

C#
public static float Sum (this System.Collections.Generic.IEnumerable<float> source);

Parametry

source
IEnumerable<Single>

Sekwencja wartości do Single obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum(IEnumerable<Single>) metody do sumowania wartości sekwencji.

C#
List<float> numbers = new List<float> { 43.68F, 1.25F, 583.7F, 6.5F };

float sum = numbers.Sum();

Console.WriteLine("The sum of the numbers is {0}.", sum);

/*
 This code produces the following output:

 The sum of the numbers is 635.13.
*/

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Nullable<Int32>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczanych Int32 do wartości null.

C#
public static int? Sum (this System.Collections.Generic.IEnumerable<int?> source);

Parametry

source
IEnumerable<Nullable<Int32>>

Sekwencja wartości dopuszczanych Int32 do wartości null do obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Int32.MaxValue.

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Nullable<Single>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczanych Single do wartości null.

C#
public static float? Sum (this System.Collections.Generic.IEnumerable<float?> source);

Parametry

source
IEnumerable<Nullable<Single>>

Sekwencja wartości dopuszczanych Single do wartości null do obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum(IEnumerable<Nullable<Single>>) metody do sumowania wartości sekwencji.

C#
float?[] points = { null, 0, 92.83F, null, 100.0F, 37.46F, 81.1F };

float? sum = points.Sum();

Console.WriteLine("Total points earned: {0}", sum);

/*
 This code produces the following output:

 Total points earned: 311.39
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Nullable<Int64>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczanych Int64 do wartości null.

C#
public static long? Sum (this System.Collections.Generic.IEnumerable<long?> source);

Parametry

source
IEnumerable<Nullable<Int64>>

Sekwencja wartości dopuszczanych Int64 do wartości null do obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Int64.MaxValue.

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Nullable<Double>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczanych Double do wartości null.

C#
public static double? Sum (this System.Collections.Generic.IEnumerable<double?> source);

Parametry

source
IEnumerable<Nullable<Double>>

Sekwencja wartości dopuszczanych Double do wartości null do obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Double.MaxValue.

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Int32>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Int32 wartości.

C#
public static int Sum (this System.Collections.Generic.IEnumerable<int> source);

Parametry

source
IEnumerable<Int32>

Sekwencja wartości do Int32 obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Int32.MaxValue.

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Int64>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Int64 wartości.

C#
public static long Sum (this System.Collections.Generic.IEnumerable<long> source);

Parametry

source
IEnumerable<Int64>

Sekwencja wartości do Int64 obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Int64.MaxValue.

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Double>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Double wartości.

C#
public static double Sum (this System.Collections.Generic.IEnumerable<double> source);

Parametry

source
IEnumerable<Double>

Sekwencja wartości do Double obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Double.MaxValue.

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Decimal>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Decimal wartości.

C#
public static decimal Sum (this System.Collections.Generic.IEnumerable<decimal> source);

Parametry

source
IEnumerable<Decimal>

Sekwencja wartości do Decimal obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Decimal.MaxValue.

Uwagi

Metoda Sum(IEnumerable<Decimal>) zwraca zero, jeśli source nie zawiera żadnych elementów.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum(IEnumerable<Nullable<Decimal>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczanych Decimal do wartości null.

C#
public static decimal? Sum (this System.Collections.Generic.IEnumerable<decimal?> source);

Parametry

source
IEnumerable<Nullable<Decimal>>

Sekwencja wartości dopuszczanych Decimal do wartości null do obliczenia sumy.

Zwraca

Suma wartości w sekwencji.

Wyjątki

source to null.

Suma jest większa niż Decimal.MaxValue.

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Single>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Single wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static float Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,float> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Single>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector to null.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) metody sumowania przewidywanych wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Metoda Sum<TSource>(IEnumerable<TSource>, Func<TSource,Single>) zwraca zero, jeśli source nie zawiera żadnych elementów.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra projektuje elementy członkowskie source w typie liczbowym, w szczególności Single.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Int64>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości null, które są uzyskiwane Int64 przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

C#
public static long? Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,long?> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Nullable<Int64>>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector to null.

Suma jest większa niż Int64.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) metody sumowania przewidywanych wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , która projektuje elementy członkowskie source w typie liczbowym, selectorw szczególności Nullable<Int64> w języku C# lub Nullable(Of Int64) w Visual Basic

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Int32>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości null, które są uzyskiwane Int32 przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

C#
public static int? Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,int?> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Nullable<Int32>>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector to null.

Suma jest większa niż Int32.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) metody sumowania przewidywanych wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podajesz funkcję , selectorktóra projektuje elementy członkowskie source typu liczbowego, w szczególności Nullable<Int32> w języku C# lub Nullable(Of Int32) Visual Basic.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Double>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości null, które są uzyskiwane Double przez wywołanie funkcji transform w każdym elemecie sekwencji danych wejściowych.

C#
public static double? Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,double?> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Nullable<Double>>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector to null.

Suma jest większa niż Double.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) metody sumowania przewidywanych wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podajesz funkcję , selectorktóra projektuje elementy członkowskie source typu liczbowego, w szczególności Nullable<Double> w języku C# lub Nullable(Of Double) Visual Basic.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() tłumaczy się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Single>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczających wartość null, które są uzyskiwane Single przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static float? Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,float?> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Nullable<Single>>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector to null.

Przykłady

W poniższym przykładzie kodu pokazano, jak użyć Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) metody sumowania przewidywanych wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podajesz funkcję , selectorktóra projektuje elementy członkowskie source typu liczbowego, w szczególności Nullable<Single> w języku C# lub Nullable(Of Single) Visual Basic.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Int64>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Int64 wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static long Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,long> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Int64>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector ma wartość null.

Suma jest większa niż Int64.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak za pomocą Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) funkcji zsumować przewidywane wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra rzutuje elementy członkowskie source obiektu na typ liczbowy, w szczególności Int64.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Int32>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Int32 wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static int Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,int> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Int32>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector ma wartość null.

Suma jest większa niż Int32.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak za pomocą Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) funkcji zsumować przewidywane wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra rzutuje elementy członkowskie source obiektu na typ liczbowy, w szczególności Int32.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Double wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static double Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,double> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Double>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector ma wartość null.

Suma jest większa niż Double.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak za pomocą Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) funkcji zsumować przewidywane wartości sekwencji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra rzutuje elementy członkowskie source obiektu na typ liczbowy, w szczególności Double.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Decimal>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji Decimal wartości uzyskanych przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static decimal Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,decimal> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Decimal>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector ma wartość null.

Suma jest większa niż Decimal.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak za pomocą Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) funkcji zsumować przewidywane wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra rzutuje elementy członkowskie source obiektu na typ liczbowy, w szczególności Decimal.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Sum<TSource>(IEnumerable<TSource>, Func<TSource,Nullable<Decimal>>)

Źródło:
Sum.cs
Źródło:
Sum.cs
Źródło:
Sum.cs

Oblicza sumę sekwencji wartości dopuszczających wartość null, które są uzyskiwane Decimal przez wywołanie funkcji przekształcania dla każdego elementu sekwencji danych wejściowych.

C#
public static decimal? Sum<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,decimal?> selector);

Parametry typu

TSource

Typ elementów elementu source.

Parametry

source
IEnumerable<TSource>

Sekwencja wartości, które są używane do obliczania sumy.

selector
Func<TSource,Nullable<Decimal>>

Funkcja transformacji do zastosowania do każdego elementu.

Zwraca

Suma przewidywanych wartości.

Wyjątki

source lub selector ma wartość null.

Suma jest większa niż Decimal.MaxValue.

Przykłady

W poniższym przykładzie kodu pokazano, jak za pomocą Sum<TSource>(IEnumerable<TSource>, Func<TSource,Double>) funkcji zsumować przewidywane wartości sekwencji.

Uwaga

W tym przykładzie kodu użyto przeciążenia metody, która różni się od określonego przeciążenia opisanego w tym artykule. Aby rozszerzyć przykład na przeciążenie opisane w tym artykule, zmień treść selector funkcji.

C#
class Package
{
    public string Company { get; set; }
    public double Weight { get; set; }
}

public static void SumEx1()
{
    List<Package> packages =
        new List<Package>
            { new Package { Company = "Coho Vineyard", Weight = 25.2 },
              new Package { Company = "Lucerne Publishing", Weight = 18.7 },
              new Package { Company = "Wingtip Toys", Weight = 6.0 },
              new Package { Company = "Adventure Works", Weight = 33.8 } };

    double totalWeight = packages.Sum(pkg => pkg.Weight);

    Console.WriteLine("The total weight of the packages is: {0}", totalWeight);
}

/*
 This code produces the following output:

 The total weight of the packages is: 83.7
*/

Uwagi

Elementy, w source których są null wykluczone z obliczeń sumy. Ta metoda zwraca zero, jeśli source nie zawiera żadnych elementów lub wszystkie elementy to null.

Tę metodę można zastosować do sekwencji dowolnych wartości, jeśli podasz funkcję , selectorktóra rzutuje elementy członkowskie source w typ liczbowy, w szczególności Nullable<Decimal> w języku C# lub Nullable(Of Decimal) Visual Basic.

W składni wyrażenia zapytania języka Visual Basic klauzula Aggregate Into Sum() przekłada się na wywołanie Sumelementu .

Zobacz też

Dotyczy

.NET 9 i inne wersje
Produkt Wersje
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0