為什么?當我保存2個圖像時,第一個保存已損壞,第二個根本沒有保存我想保存文件而不卡住客戶端(Task.Run)和不卡住服務器(異步等待)Task.Run(async () => { foreach (var item in Images) { // item.File is IFormFile array await SaveFile(item.FileSavePath, item.File); }}); public static async Task SaveFile(string filePath, IFormFile file) { string folderPath = Path.GetDirectoryName(filePath); if (!Directory.Exists(folderPath)) Directory.CreateDirectory(folderPath); using (var fileStream = new FileStream(filePath, FileMode.Create)) { await file.CopyToAsync(fileStream); } }
1 回答

慕森卡
TA貢獻1806條經驗 獲得超8個贊
如果未等待,則操作幾乎肯定會在實際任務完成之前返回。當操作超出范圍時,它會隨之獲取其所有作用域變量,包括從 post 正文綁定的實例。這將導致寫入被過早取消,留下一個損壞的文件(因為流在寫入過程中被破壞)。將引發異常,但由于您正在新線程中運行,因此它不會通過請求管道冒泡,并且會被有效地吞噬。Task.RunSaveFileIFormFile
長短,等待您的電話。但是,一旦你這樣做了,那么在這里使用實際上就沒有意義了。所以,你最好完全擺脫它。相反,只需啟動所有任務,然后等待:Task.RunTask.RunTask.WhenAll
var tasks = new List<Task>();
foreach (var item in Images)
{
// item.File is IFormFile array
tasks.Add(SaveFile(item.FileSavePath, item.File));
}
await Task.WhenAll(tasks);
任務返回熱,或已啟動。因此,等待在 foreach 中保存每個項目將導致任務被串行處理。只需將它們保存到列表中,即可使它們全部啟動并基本并行運行。然后,您只需等待列表中所有任務的完成,以防止操作返回,直到工作完成。
- 1 回答
- 0 關注
- 81 瀏覽
添加回答
舉報
0/150
提交
取消