当我处理LINQ序列时,我想将每个项目发送到一个返回void的方法,避免了foreach循环.但是,我没有找到一个优雅的方式来做到这一点.今天我写了下面的代码:
private StreamWriter _sw;
private void streamToFile(List<ErrorEntry> errors)
{
if (_sw == null)
{
_sw = new StreamWriter(Path.Combine
(Path.GetDirectoryName(_targetDatabasePath),"errors.txt"));
}
Func<ErrorEntry,bool> writeSelector =
(e) => { _sw.WriteLine(getTabDelimititedLine(e)); return true; };
errors.Select(writeSelector);
_sw.Flush();
}
你可以看到,我写了一个只返回true的lambda函数,我意识到Select方法将返回一个布尔序列,我只是忽略该序列.然而,这似乎有点无聊和…有没有什么优雅的方式来做到这一点?或者我只是错误地使用LINQ?
谢谢.
解决方法
首先,您当前的代码将无法正常工作.
选择和大多数其他LINQ方法都使用延迟执行,这意味着在枚举结果之前,它们实际上不会执行任何操作.
选择和大多数其他LINQ方法都使用延迟执行,这意味着在枚举结果之前,它们实际上不会执行任何操作.
一般来说,您不应该在LINQ查询中使用带有副作用的lambda.
要回答你的问题,你应该使用foreach循环.
您正在寻找ForEach扩展方法; Eric Lippert explains why Microsoft didn’t write one.
如果你真的想,你可以自己写一个:
public static void ForEach<T>(this IEnumerable<T> sequence,Action<T> action) {
if (sequence == null) throw new ArgumentNullException("sequence");
if (action == null) throw new ArgumentNullException("action");
foreach(T item in sequence)
action(item);
}
//Return false to stop the loop
public static void ForEach<T>(this IEnumerable<T> sequence,Func<T,bool> action) {
if (sequence == null) throw new ArgumentNullException("sequence");
if (action == null) throw new ArgumentNullException("action");
foreach(T item in sequence)
if (!action(item))
return;
}