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
Combinare Container Queries e Media Queries
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Ricevere notifiche sui test con Azure Load Testing
Managed deployment strategy in Azure DevOps
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Gestire gli accessi con Token su Azure Container Registry
Gestione dei nomi con le regole @layer in CSS
Introduzione ai web component HTML
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Generare velocemente pagine CRUD in Blazor con QuickGrid
Ottimizzare le pull con Artifact Cache di Azure Container Registry