我有一个对象列表.单个对象条目的一个属性是金额.我如何得到金额的总和?
如果我的列表是double类型,我可能会做这样的事情:
double total = myList.Sum();
Run Code Online (Sandbox Code Playgroud)
但是我想要类似的东西,但这种语法是不正确的.
double total = myList.amount.Sum();
Run Code Online (Sandbox Code Playgroud)
我该怎么做呢?我希望尽可能使用Sum函数,而不是循环并计算值.
Ale*_* LE 277
using System.Linq;
Run Code Online (Sandbox Code Playgroud)
...
double total = myList.Sum(item => item.Amount);
Run Code Online (Sandbox Code Playgroud)
Gre*_*inn 32
如果你需要在符合特定条件的物品上进行...
double total = myList.Where(item => item.Name == "Eggs").Sum(item => item.Amount);
Run Code Online (Sandbox Code Playgroud)
另一种选择:
myPlanetsList.Select(i => i.Moons).Sum();
Run Code Online (Sandbox Code Playgroud)
以下是您可以运行来进行此类测试的示例代码:
var f = 10000000;
var p = new int[f];
for(int i = 0; i < f; ++i)
{
p[i] = i % 2;
}
var time = DateTime.Now;
p.Sum();
Console.WriteLine(DateTime.Now - time);
int x = 0;
time = DateTime.Now;
foreach(var item in p){
x += item;
}
Console.WriteLine(DateTime.Now - time);
x = 0;
time = DateTime.Now;
for(int i = 0, j = f; i < j; ++i){
x += p[i];
}
Console.WriteLine(DateTime.Now - time);
Run Code Online (Sandbox Code Playgroud)
复杂对象的相同示例是:
void Main()
{
var f = 10000000;
var p = new Test[f];
for(int i = 0; i < f; ++i)
{
p[i] = new Test();
p[i].Property = i % 2;
}
var time = DateTime.Now;
p.Sum(k => k.Property);
Console.WriteLine(DateTime.Now - time);
int x = 0;
time = DateTime.Now;
foreach(var item in p){
x += item.Property;
}
Console.WriteLine(DateTime.Now - time);
x = 0;
time = DateTime.Now;
for(int i = 0, j = f; i < j; ++i){
x += p[i].Property;
}
Console.WriteLine(DateTime.Now - time);
}
class Test
{
public int Property { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
关闭编译器优化后我的结果是:
00:00:00.0570370 : Sum()
00:00:00.0250180 : Foreach()
00:00:00.0430272 : For(...)
Run Code Online (Sandbox Code Playgroud)
第二个测试是:
00:00:00.1450955 : Sum()
00:00:00.0650430 : Foreach()
00:00:00.0690510 : For()
Run Code Online (Sandbox Code Playgroud)
看起来 LINQ 通常比 foreach(...) 慢,但对我来说奇怪的是 foreach(...) 似乎比 for 循环更快。
归档时间: |
|
查看次数: |
180857 次 |
最近记录: |