函数在等待异步完成之前返回

时间:2020-02-06 15:13:57

标签: c# .net asynchronous async-await sendgrid

我正在尝试通过SendGrid API发送2封电子邮件。有时0发送,有时1发送,有时都发送。似乎该功能没有等待承诺。如何解决它,使其始终发送两封电子邮件?

我的功能如下:

private async Task<bool> SendMails(string email, string name, string pdfPath, string imgPath)
{
    var client = new SendGridClient(_config["SendGrid:Key"]);
    bool messagesSent = false;
    var messageClient = new SendGridMessage
    {
        From = new EmailAddress(_config["SendGrid:Recipient"]),
        Subject = "Testmail",
        HtmlContent = _textManager.Get("getMailHtml")
    };

    var messageSecondClient = new SendGridMessage
    {
        From = new EmailAddress(_config["SendGrid:Recipient"]),
        Subject = "Second Testmail",
        HtmlContent = _textManager.Get("getSecondMailHtml")
    };

    messageClient.AddTo(email, name);
    messageSecondClient.AddTo(email, name);

    string[] fileListClient = new string[] { pdfPath };
    string[] fileListSecond = new string[] { pdfPath, imgPath };

    foreach (var file in fileListClient)
    {
        var fileInfo = new FileInfo(file);

        if (fileInfo.Exists)
            await messageClient.AddAttachmentAsync(fileInfo.Name, fileInfo.OpenRead());
    }

    foreach (var file in fileListSecond)
    {
        var fileInfo = new FileInfo(file);

        if (fileInfo.Exists)
            await messageSecondClient.AddAttachmentAsync(fileInfo.Name, fileInfo.OpenRead());
    }

    var responseClient = await client.SendEmailAsync(messageClient);
    var responseSecond = await client.SendEmailAsync(messageSecondClient);

    if (responseClient.StatusCode.ToString() == "202" && responseSecond.StatusCode.ToString() == "202")
    {
        messagesSent = true;
    }
    return messagesSent;
}

这就是我的称呼方式:

            Task<bool> sendMails = await Task.FromResult(SendMails(formCollection["email"], formCollection["name"], pdfPath, imgPath));

            if (!sendMails.Result)
            {
                errorMessage = "Error sending mails.";
            }

2 个答案:

答案 0 :(得分:6)

您正在阻止异步任务:

if (!sendMails.Result)

,并且可以cause a deadlock。而不是阻止,请使用await

您还可以摆脱isn't doing anything at allawait Task.FromResult

bool sentMails = await SendMails(formCollection["email"], formCollection["name"], pdfPath, imgPath);

if (!sentMails)
{
  errorMessage = "Error sending mails.";
}

答案 1 :(得分:5)

Task.FromResult返回已经完成的 new Task,而不是Task返回的SendMails

没有任何事情等待SendMails的完成。

只需等待方法返回的Task

bool result = await SendMails(formCollection["email"], formCollection["name"], pdfPath, imgPath);

await关键字为您解开Task.Result