I Task sono oggetti che rappresentano un'operazione che può avere uno stato di successo e di fallimento, e tramite il pattern async/await ci permettono facilmente di scrivere codice asincrono. Normalmente, poiché utilizziamo funzioni asincrone del .NET Framework o di WinRT, il nostro codice sfrutta le parole chiavi async/await per attendere e per restituire un nuovo Task che ne ingloba degli altri, ma non sempre questo è possibile.
Supponiamo, per esempio, di avere una Popup per mostrare delle informazioni all'utente, dandogli la possibilità con dei pulsanti di rispondere positivamente o negativamente. Il codice per realizzare questo in WinRT, e in maniera molto simile anche in WPF, è il seguente:
// Creo l'user control con l'interfaccia var uc = new MyUserControl(); uc.yesButton.Click += (s, e) => { // TODO }; // Mostro la popup Popup popup = new Popup(); popup.Child = uc; popup.IsOpen = true;
Per rendere più facile la programmazione, vogliamo a questo punto utilizzare i Task per mostrare la Popup e attendere il relativo responso. Inglobiamo quindi il codice precedente in una funzione che crea la Popup e restituisce un Task.
public static Task<bool> AskAsync() { // ... codice precedente ... var source = new TaskCompletionSource<bool>(); return source.Task; }
Per farlo utilizziamo l'oggetto TaskCompletionSource che ci permette di avere l'oggetto Task e di controllarlo. I relativi metodi TrySetResult e TrySetCanceled ci permettono di completare il Task con successo o meno, permettendo di leggere il risultato e di proseguire per chi sta aspettando l'esito. Nello snippet seguente impostiamo il risultato alla pressione del pulsante sì.
uc.yesButton.Click += (s, e) => { source.TrySetResult(true); };
A questo punto per mostrare la Popup non dobbiamo far altro che invocare la nostra funzione asincrona.
bool r = await Helper.AskAsync(); if (r) { // Risposta positiva }
Eventualmente, possiamo indicare un'eccezione mediante il metodo TrySetException.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Creare una libreria CSS universale: Nav menu
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Utilizzare WhenEach per processare i risultati di una lista di task
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Disabilitare automaticamente un workflow di GitHub (parte 2)
Utilizzare Azure AI Studio per testare i modelli AI
La gestione della riconnessione al server di Blazor in .NET 9
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Usare le navigation property in QuickGrid di Blazor