ASP.NET Web Forms supporta, fin dalla versione 2.0, l'esecuzione di codice asincrono, come abbiamo visto nello script #814. L'interfaccia esposta da ASP.NET è immediata da utilizzare con l'Asynchronous Programming Model (APM), cioè quando l'esecuzione asincrona è implementata tramite la coppia di metodi Begin... e End..., dato che è sufficiente invocare tali metodi nei rispettivi handler, come mostrato nel codice in basso:
private IAsyncResult BeginProcess(object sender, EventArgs e, AsyncCallback callback, object data) { // altro codice qui .. return BeginDoingAsyncWork(callback, data); } private void EndProcess(IAsyncResult result) { // altro codice qui .. var result = EndDoingAsyncWork(result); }
Quando il flusso delle operazioni asincrone è più complesso, lo strumento migliore di cui possiamo avvalerci è però costituito dai Task, introdotti con il .NET Framework 4.0, di cui abbiamo parlato in precedenza. Essi espongono un eccellente modello a oggetti, che rende estremamente facile e intuitivo concatenare o eseguire in parallelo diverse operazioni:
var taskList = new List<Task>(); taskList.Add(Task.Factory.StartNew(() => doSomeWork())); taskList.Add(Task.Factory.StartNew(() => doSomeOtherWork()) .ContinueWith((t) => someContinuationWork())); Task.Factory.ContinueWhenAll(taskList.ToArray(), (t) => finalWork());
Grazie al codice precedente, infatti, l'esecuzione dei vari metodi doSomeWork, doSomeOtherWork, ecc... viene orchestrata secondo il flusso mostrato in figura.
Questa tecnica può essere comunque utilizzata con le Async Pages di ASP.NET, dato che l'oggetto Task implementa l'interfaccia IAsyncResult e quindi può essere utilizzato come valore di ritorno per un metodo di tipo BeginEventHandler; bisogna però ricordarsi di invocare il metodo di callback fornito da ASP.NET al termine dell'esecuzione, così che l'infrastruttura possa essere notificata della conclusione dell'operazione asincrona:
private IAsyncResult beginTasks(object sender, EventArgs e, AsyncCallback callback, object extraData) { var taskList = new List<Task>(); taskList.Add(Task.Factory.StartNew(() => doSomeWork())); taskList.Add(Task.Factory.StartNew(() => doSomeOtherWork()) .ContinueWith((t) => someContinuationWork())); var result = Task.Factory .ContinueWhenAll(taskList.ToArray(), (t) => finalWork()); // alla conclusione del flusso di task precedenti, bisogna // eseguire il metodo di callback return result.ContinueWith((task) => callback(task)); }
Per approfondimenti
Leggere un feed RSS in modalità asincrona con ASP.NET 2.0https://www.aspitalia.com/script/814/Leggere-Feed-RSS-Modalita-Asincrona-ASP.NET-2.0.aspx
Multithreading e parallelismo con il .NET Framework 4.0
https://www.winfxitalia.com/articoli/netfx4/multithreading-parallelismo.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare le collection expression per inizializzare una lista di oggetti in C#
Utilizzare la libreria Benchmark.NET per misurare le performance
Evitare la script injection nelle GitHub Actions
Criptare la comunicazione con mTLS in Azure Container Apps
Utilizzare Tailwind CSS all'interno di React: primi componenti
Specificare il versioning nel path degli URL in ASP.NET Web API
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Gestire errori funzionali tramite exception in ASP.NET Core Web API
Eseguire una query su SQL Azure tramite un workflow di GitHub
Miglioramenti nelle performance di Angular 16
Configurare dependabot per aggiornare le dipendenze di terze parti con GitHub Actions
Aggiungere interattività lato server in Blazor 8
I più letti di oggi
- Utilizzare WebAssembly con .NET, ovunque
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- Utilizzare il trigger SQL con le Azure Function
- Disabilitare automaticamente un workflow di GitHub (parte 2)
- Ottimizzazione dei block template in Angular 17
- Paginare i risultati con QuickGrid in Blazor