本文由机器翻译。若要查看英语原文,请勾选“英语”复选框。 也可将鼠标指针移到文本上,在弹出窗口中显示英语原文。
翻译
英语

Enumerable.Sum<TSource> 方法 (IEnumerable<TSource>, Func<TSource, Nullable<Double>>)

 

计算可以为 null 的序列的和 Double 通过调用对输入序列中的每个元素的转换函数获得的值。

命名空间:   System.Linq
程序集:  System.Core(位于 System.Core.dll)

public static Nullable<double> Sum<TSource>(
	this IEnumerable<TSource> source,
	Func<TSource, Nullable<double>> selector
)

参数

source
Type: System.Collections.Generic.IEnumerable<TSource>

使用要计算的总和的值的序列。

selector
Type: System.Func<TSource, Nullable<Double>>

应用于每个元素的转换函数。

返回值

Type: System.Nullable<Double>

投影值的总和。

类型参数

TSource

中的元素的类型 source

Exception Condition
ArgumentNullException

sourceselectornull

此方法返回零 source 不包含任何元素。

结果不包含值 null

如果提供了函数时将此方法应用到序列中的任意值 selector, ,项目的成员 source 为数值类型,特别是 Nullable<Double> 在 C# 或 Nullable(Of Double) 中 Visual Basic。

在 Visual Basic 查询表达式语法中, Aggregate Into Sum() 子句转换为的一个调用 Sum

下面的代码示例演示如何使用 Sum<TSource>(IEnumerable<TSource>, Func<TSource, Double>) 序列的投影的值的和。

System_CAPS_note说明

此代码示例使用此重载方法的重载,该重载与本主题介绍的特定重载不同。 若要将此示例扩展到本主题,请更改 selector 函数体。

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
*/

通用 Windows 平台
自 8 起可用
.NET Framework
自 3.5 起可用
可移植类库
可移植 .NET 平台 中受支持
Silverlight
自 2.0 起可用
Windows Phone Silverlight
自 7.0 起可用
Windows Phone
自 8.1 起可用
返回页首
显示: