我试图异步我的原始代码
for(var item in items) { dbAccess.Save(item); }
哪个工作正常:
var tasks = new List<Task>(); for(var item in items) { tasks.Add(dbAccess.SaveAsync(item)); } await Task.WhenAll(tasks);
但是,在我保存并将项目添加到我的数据库之前,我需要添加一个额外的清理调用:
var tasks = new List<Task>(); for(var item in items) { tasks.Add(dbAccess.DeleteAsync(item.id)); tasks.Add(dbAccess.SaveAsync(item)); } await Task.WhenAll(tasks);
上面的代码不正确,因为在相应的DeleteAsync完成之前不应执行SaveAsync.换句话说,删除必须始终在为每个项目保存之前进行,但项目的顺序无关紧要.
有一个完美的方法来做到这一点?