我有以下代码:
IEnumerable<Vehicles> Vehicles;
for (int count = 0; count < Vehicles.Count(); count++)
{
if (Vehicles.ElementAt(count).Mode)
{
}
}
我如何实现带有 if 条件的 Lambda 表达式 foreach?
我试过这个:
Vehicles.ToList().ForEach(i=>i.Mode)
并对此感到震惊,因为我不知道如何检查条件,因为智能感知也没有显示 where 子句。非常感谢任何帮助。我也想在循环中使用计数值....
最佳答案
我假设 Mode
是一个 bool
属性。然后你只需要这个小查询和一个foreach
:
foreach(Vehicles v in Vehicles.Where(x => x.Mode))
{
// do something with it
}
您的方法效率很低。如果 Vehicles
不是列表或数组,Vehicles.Count()
枚举整个查询以计算计数。更糟糕的是在循环中使用 ElementAt
,因为它也在枚举整个序列,直到它位于给定的索引处,但即使对于每次迭代也是如此。
使用 Vehicles.ToList().ForEach
的最后一种方法是创建一个新列表,原因不明,只是为了能够使用 ForEach
方法,它没有优于普通的 foreach
循环。它还不过滤此属性的车辆。
如果你需要一个计数器,你只需要增加一个局部变量:
int count = 0;
foreach(Vehicles v in Vehicles.Where(x => x.Mode))
{
count++;
// do something with it
}
或者直接在LINQ查询中选择索引成匿名类型:
var modeVehicles = Vehicles
.Where(x => x.Mode)
.Select((x, index) => new { Count = index + 1, Vehicle = x });
foreach(var x in modeVehicles)
{
int count = x.Count;
Vehicles v = x.Vehicle;
// do something with it
}
这两种方法都返回与谓词匹配的车辆数量(Mode
is true
)。
如果你想知道这辆车在所有车辆(包括不匹配的车辆)中的数量,你有三个选择:
1.) 如果它实际上是一个列表或数组(在这种情况下是首选),则使用 for 循环:
var list = Vehicles as IList<Vehicles>;
if(list != null)
{
for (int count = 0; count < list.Count; count++)
{
if (list[count].Mode)
{
// do something with it
}
}
}
2.) 使用普通的 foreach
和 if
:
int count = 0;
foreach(Vehicles v in Vehicles)
{
if (v.Mode)
{
// do something with it
}
count++;
}
3.) 或像这样的 LINQ 查询(注意在 Where
之前先选择索引):
var modeVehicles = Vehicles
.Select((x, index) => new { Count = index + 1, Vehicle = x })
.Where(x => x.Mode);
foreach (var x in modeVehicles)
{
int count = x.Count;
Vehicles v = x.Vehicle;
// do something with it
}
关于c# - Foreach 上 IEnumerable<> 与 if 条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34614359/