Abbiamo sottolineato più volte come l'esecuzione asincrona di metodi potenzialmente lunghi porti dei benefici importanti a livello di scalabilità del sistema: in questo modo, infatti, il task da eseguire viene preso in carico da un worker thread, così che nel frattempo il thread utilizzato dal server per rispondere alla request possa essere allocato per evadere un'ulteriore richiesta.
Grazie alle keyword async e await e al nuovo supporto di Entity Framework 6, possiamo facilmente sfruttare questa tecnica di sviluppo anche nel caso dell'accesso ai dati. Per esempio, se dobbiamo visualizzare le informazioni di una particolare Person, possiamo implementare la action seguente:
public async Task<ActionResult> Edit(int id) { Person person = await db.People.FindAsync(id); if (person == null) { return HttpNotFound(); } return View(person); }
Nel codice in alto, in particolare, oltre ad aver dichiarato il metodo come async (restituendo quindi un Task
Nel caso del salvataggio, l'esempio è assolutamente analogo, garzie all'uso di SaveChangesAsync in luogo di SaveChanges:
[HttpPost] public async Task<ActionResult> Edit(Person person) { if (ModelState.IsValid) { db.Entry(person).State = EntityState.Modified; await db.SaveChangesAsync(); RefreshHub.Refresh(); return RedirectToAction("Index"); } return View(person); }
Come possiamo notare, grazie alle keyword async/await, il codice da scrivere non presenta alcuna complessità aggiuntiva rispetto alla versione sincrona: pertanto è assolutamente conveniente usare questa tecnica fin da subito.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Short-circuiting della Pipeline in ASP.NET Core
Utilizzare gli snapshot con Azure File shares
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
.NET Conference Italia 2023
Effettuare lo stream della risposta in ASP.NET Core tramite IAsyncEnumerable
Recuperare un elemento inserito nella cache del browser tramite API JavaScript
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Usare Refit e Polly in Blazor per creare client affidabili e fortemente tipizzati
Personalizzare l'errore del rate limiting middleware in ASP.NET Core
Limitare le richieste lato server con l'interactive routing di Blazor 8
Eseguire attività con Azure Container Jobs