• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

[ASP.NET] Kiedy tworzyć asynchroniczne metody kontrolera?

0 głosów
59 wizyt
pytanie zadane 9 maja 2021 w C# przez dawid2002 Mądrala (5,170 p.)
edycja 9 maja 2021 przez dawid2002

Cześć wszystkim! Ostatnio rozmyślam nad jednym dylematem - kiedy tworzyć asynchroniczne metody kontrolera a kiedy synchroniczne? Kiedyś spotkałem się z taką opinią, że metody kontrolera powinny być prawie zawsze asynchroniczne ze względu na responsywność serwera, chodzi mi o to, że jeśli będzie dużo żądań to kod synchroniczny może mieć problem, aby to obsłużyć i wątek główny może być zawalony przez te żądania. Oprócz tego spotkałem się jeszcze z taką opinią, że metody te powinny być asynchroniczne wtedy kiedy trzeba użyć słówka await, bądź wielokrotnie czytałem, że powinniśmy używać takich metody gdy mamy do czynienia z operacjami I/O oraz odpytywaniem bazy danych.

Odpowiedź na to pytanie jest mi potrzebna bo ostatnio napisałem taki kod:

public ViewResult Menu(string selectedCategory)
        {
            ViewBag.SelectedCategory = selectedCategory;
            var products = _context.Products;
            var allCategoryAndCount = (ConfigurationManager.AppSettings["all_category_option_name"], products.Count());
            
            IQueryable<(string option, int productsCount)> menuOptionsWithCounts = products
                .AsEnumerable()
                .Select(prod => prod.Category)
                .Distinct()
                .OrderBy(category => category)
                .Select(category => (category, products.Count(prod => prod.Category == category)))
                .Prepend(allCategoryAndCount);
            
            return View(menuOptionsWithCounts);
        }

I teraz nie wiem czy nie przekształcić tego w coś takiego:

public async Task<ViewResult> Menu(string selectedCategory)
        {
            ViewBag.SelectedCategory = selectedCategory;
            var products = this.repository.Products;
            var allCategoryAndCount = (ConfigurationManager.AppSettings["all_category_option_name"], products.Count());
            
            var menuOptionsWithCounts = await products
                .AsEnumerable()
                .Select(prod => prod.Category)
                .Distinct()
                .OrderBy(category => category)
                .Select(category => (category, products.Count(prod => prod.Category == category)))
                .Prepend(allCategoryAndCount)
                .ToListAsync();
            
            return View(menuOptionsWithCounts);
        }

Z góry dzięki za pomoc!

komentarz 9 maja 2021 przez JakSky Stary wyjadacz (14,250 p.)
Metod asynchronicznych używasz, gdy wykonujesz operacje I/O lub długotrwałe prace. Metoda z async, ale bez await jest zwykłą metodą i z metodami asynchronicznymi nie ma nic wspólnego. Musisz użyć słowa await.

1 odpowiedź

0 głosów
odpowiedź 10 maja 2021 przez cava96 Gaduła (3,660 p.)
Warto używać await podczas korzystania z bazy danych, dlaczego ?

Ponieważ gdy mamy jakąś sekwencje zapytań do bazy (np. 2 - 3 zapytania) to w zależności od obciążenia serwera DB wartość 3 może być zwrócona szybciej niż 1 zapytania pomimo, że ono jest nam potrzebne na start

Podobne pytania

0 głosów
2 odpowiedzi 546 wizyt
pytanie zadane 15 sierpnia 2019 w C# przez Szaradek Obywatel (1,320 p.)
0 głosów
0 odpowiedzi 200 wizyt
+1 głos
1 odpowiedź 1,776 wizyt
pytanie zadane 28 stycznia 2018 w C# przez Kfiotek Początkujący (370 p.)

86,541 zapytań

135,291 odpowiedzi

300,649 komentarzy

57,288 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...