¿Dónde marco una expresión lambda asíncrona?


215

Tengo este código:

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));
}

... que la inspección de Resharper se quejó con, " Debido a que esta llamada no se espera, la ejecución del método actual continúa antes de que se complete la llamada. Considere aplicar el operador 'esperar' al resultado de la llamada " (en la línea con el comentario).

Y así, prefiero un "esperar" pero, por supuesto, también necesito agregar un "asíncrono" en alguna parte, pero ¿dónde?



1
@samsara: Bien, me pregunto cuándo finalmente documentaron eso en algún lugar fuera de la especificación de C #. IIRC, no existía documentación en el momento en que se hizo esta pregunta.
BoltClock

Respuestas:


365

Para marcar una lambda asíncrona, simplemente anteponga asyncantes de su lista de argumentos:

// 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);
}));

Recibo un error de Visual Studio de que los métodos de vacío asíncrono no son compatibles.
Kevin Burton

@Kevin Burton: Sí, los vacíos asíncronos generalmente solo se limitan a los controladores de eventos. La API que está utilizando no es asíncrona o tiene una versión asincrónica que espera una tarea asincrónica lambda.
BoltClock

22

Y para aquellos de ustedes que usan una expresión anónima:

await Task.Run(async () =>
{
   SQLLiteUtils slu = new SQLiteUtils();
   await slu.DeleteGroupAsync(groupname);
});
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.