您正在关闭循环变量。不要那样做 取一份副本:
foreach (string path in paths)
{
string pathCopy = path;
var task = Task.Factory.StartNew(() =>
{
Boolean taskResult = ProcessPicture(pathCopy);
return taskResult;
});
// See note at end of post
task.ContinueWith(t => result &= t.Result);
tasks.Add(task);
}
您当前的代码正在捕获path
- 创建任务时不是它的 值 ,而是变量本身。每次循环时,该变量都会更改值-因此可以在调用委托时轻松更改它。
通过获取变量的副本,您在每次循环时都会引入一个 新 变量-当捕获 该 变量时,在下一次循环中将不会更改 该 变量。
埃里克·利珀特(Eric Lippert)有两篇博客文章,其中更详细地介绍了这一点:第1部分;第2部分。
别难过-这几乎使所有人都陷入困境:(
关于这一行的注意事项:
task.ContinueWith(t => result &= t.Result);
正如评论中指出的那样,这不是线程安全的。多个线程可以同时执行它,从而可能在彼此的结果上加盖印记。我没有添加锁定或类似的东西,因为它会分散问题关注的主要问题,即变量捕获。但是,值得注意的是。