您正在关闭循环变量。不要那样做 取一份副本:
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);
正如评论中指出的那样,这不是线程安全的。多个线程可以同时执行它,从而可能在彼此的结果上加盖印记。我没有添加锁定或类似的东西,因为它会分散问题关注的主要问题,即变量捕获。但是,值得注意的是。


![在foreach循环中启动任务使用最后一项的值[重复] 在foreach循环中启动任务使用最后一项的值[重复]](http://www.mshxw.com/aiimages/31/447175.png)
