Где я могу пометить лямбда-выражение как асинхронное?


215

У меня есть этот код:

private async void ContextMenuForGroupRightTapped(object sender, RightTappedRoutedEventArgs args)
{
    CheckBox ckbx = null;
    if (sender is CheckBox)
    {
        ckbx = sender as CheckBox;
    }
    if (null == ckbx)
    {
        return;
    }
    string groupName = ckbx.Content.ToString();

    var contextMenu = new PopupMenu();

    // Add a command to edit the current Group
    contextMenu.Commands.Add(new UICommand("Edit this Group", (contextMenuCmd) =>
    {
        Frame.Navigate(typeof(LocationGroupCreator), groupName);
    }));

    // Add a command to delete the current Group
    contextMenu.Commands.Add(new UICommand("Delete this Group", (contextMenuCmd) =>
    {
        SQLiteUtils slu = new SQLiteUtils();
        slu.DeleteGroupAsync(groupName); // this line raises Resharper's hackles, but appending await raises err msg. Where should the "async" be?
    }));

    // Show the context menu at the position the image was right-clicked
    await contextMenu.ShowAsync(args.GetPosition(this));
}

... что инспекция Решарпера жаловалась на: « Поскольку этот вызов не ожидается, выполнение текущего метода продолжается до завершения вызова. Рассмотрите возможность применения оператора 'await' к результату вызова " (в строке с комментарий).

И вот, я добавил к нему «ожидание», но, конечно, мне тогда тоже нужно добавить «асинхронный» - но где?



1
@samsara: Хорошо, интересно, когда они наконец-то задокументировали это где-то за пределами спецификации C #. IIRC, в то время, когда этот вопрос задавался, документации не было.
BoltClock

Ответы:


365

Чтобы отметить лямбда-асинхронность, просто добавьте asyncперед списком аргументов:

// Add a command to delete the current Group
contextMenu.Commands.Add(new UICommand("Delete this Group", async (contextMenuCmd) =>
{
    SQLiteUtils slu = new SQLiteUtils();
    await slu.DeleteGroupAsync(groupName);
}));

Я получаю сообщение об ошибке из Visual Studio, что Async void методы не поддерживаются.
Кевин Бертон

@Kevin Burton: Да, асинхронные пустоты обычно ограничиваются только обработчиками событий. Используемый вами API либо не асинхронный, либо имеет асинхронную версию, ожидающую взамен асинхронную лямбда-задачу.
BoltClock

22

А для тех из вас, кто использует анонимное выражение:

await Task.Run(async () =>
{
   SQLLiteUtils slu = new SQLiteUtils();
   await slu.DeleteGroupAsync(groupname);
});
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.