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
Rinnovare il token di una GitHub App durante l'esecuzione di un workflow
Aggiungere interattività lato server in Blazor 8
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Usare un KeyedService di default in ASP.NET Core 8
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Filtering sulle colonne in una QuickGrid di Blazor
Usare le navigation property in QuickGrid di Blazor
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Triggerare una pipeline su un altro repository di Azure DevOps
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Creare una custom property in GitHub
Ordinare randomicamente una lista in C#