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
Usare un KeyedService di default in ASP.NET Core 8
Load test di ASP.NET Core con k6
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Effettuare il pull di git LFS in un workflow di GitHub
Verificare la provenienza di un commit tramite le GitHub Actions
Le novità di Entity Framework 8
Cache policy su route groups di Minimal API in ASP.NET Core 7
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Implementare il throttling in ASP.NET Core
Usare ASP.NET Core dev tunnels per testare le applicazioni su internet
Configurare policy CORS in Azure Container Apps
Trasformare qualsiasi backend in un servizio GraphQL con Azure API Management