Diskuze: .net core DI
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 5 zpráv z 5.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
services.AddTransient<Služba, Implementace>- Každý HTTP požadavek vytvoří novou instanci služby (alokuje paměť).
Dejme tomu, že tvá služba vrací nový GUID (unikátní řetězec).
Představ si URL: http://localhost:5000/home/index
Zkus opakovaně vysílat požadavek na toto stejné URL (čili "refreshovat" stránku) a uvidíš, že GUID se pořád mění! Čili jak jsem se zmínil, Transient vytváří novou instanci pro každý HTTP požadavek.
Použivají se všude tam, kde není jistota sdílení dvou instantcí současně (což může způsobit únik paměti). Např. paralelní sdílení contextu Entity Frameworku.
services.AddScoped<Služba, Implementace> - Každý HTTP požadavek vytvoří novou instanci pro daný rozsah. Typickým příkladem jsou samotné kontrolery.
Čili kdybys refreshoval výše zmíněné URL, GUID by byl stejný jen pro home controller. Jinými slovy, instance je sdílená po dobu existence kontroleru.
A rozumím, já jsem měl právě porblém s tím EF jak zmiňuješ.Takže
vzhledem k EF mám používát Scoped? Kčemu se třeba hodí Transient? Díky
Takže vzhledem k EF mám používát Scoped?
To záleží. Pokud používáš jeden kontext ("jednu databázi") a provádíš klasické CRUD (Create, Read, Update, Delete) operace, tak v tomto případě bych nevymýšlel vesmír a zůstal u Scoped. Čili bych sdílel jednu instanci v po dobu existence kontroleru.
Typický příklad:
services.AddScoped<IEmployeeRepository, EmployeeRepository>(); kde EmployeeRepository interně implementuje Entity Framework.
K čemu se třeba hodí Transient?
Transient se hodí všude tam, kde nepotřebuješ sdílet stejnou instanci buď v rozsahu celé aplikace (Singleton) nebo v rozsahu kontroleru (Scoped). Většinou to jsou drobné služby, které dělají jednu jedinou věc.
Např. zpracování nahrané fotografie.
services.AddTransient<IPhotoService, PhotoService>(); kde PhotoService implementuje logiku pro zpracování fotografie.
Přeci jen, celá tvá aplikace nepotřebuje vědět jak zpracovat foto, že ne? Nejčastěji je to úloha jedné jediné akce (např. profil uživatele), což v tomto případě by nebylo rozumné držet instanci PhotoService po dobu existence celé aplikace (Singleton) nebo po dobu existence kontroleru (Scoped).
Závěrem:
Singletony jsou nejčastěji služby samotného frameworku (HTTP požadavky, logování, konfigurace prostředí - test, vývoj, produkce).
Scoped jsou nejčastěji repozitáře. Všechno to, co komunikuje s externím zdrojem (jako např. databáze nebo API), protože celý kontroler využívá jednu instanci kontextu (např v Index akci zobrazíš seznam výrobku, v akci Detail načteš pouze data vztahující se k danému produktu), protože je to "levnější" než vytvářet novou instanci (Transient) a je úspornější využít existující.
Transient - malé, drobné služby, které vykonají jednu jedinou věc.
Zobrazeno 5 zpráv z 5.