使用linq和for循环比较,前者2397ms,后者用时2248ms,基本差不多。
//开始计时
Stopwatch watch = new Stopwatch();
watch.Start();
//LINQ遍历选择
listSelChkCond = listSelChkCond.Select(p => { CommGX.CCommGXDB.GetFieldType(entExInfo,ref p); return p; }).ToList();
watch.Stop();
Console.WriteLine("LINQ计算耗费时间:{0}", watch.ElapsedMilliseconds); //2397
//for循环开始遍历选择
watch.Restart();
for (int n = 0; n < listSelChkCond.Count; n++)
{
CommDB.CCommStruct.CheckCondition cc = listSelChkCond[n];
CommGX.CCommGXDB.GetFieldType(entExInfo, ref cc); //ref 和 out 不能直接传带有索引器或者foreach成员的值
listSelChkCond[n] = cc;
}
watch.Stop();
Console.WriteLine("for循环计算耗费时间:{0}", watch.ElapsedMilliseconds); //2248