www.wikidata.uk-ua.nina.az
Vprovadzhennya zalezhnosti angl Dependency injection DI shablon proyektuvannya programnogo zabezpechennya sho peredbachaye nadannya zovnishnoyi zalezhnosti programnomu komponentu vikoristovuyuchi inversiyu keruvannya angl Inversion of control IoC dlya rozv yazannya otrimannya zalezhnostej Vprovadzhennya ce peredacha zalezhnosti tobto servisu zalezhnomu ob yektu tobto kliyentu Peredavati zalezhnosti kliyentu zamist dozvoliti kliyentu stvoriti servis ye fundamentalnoyu vimogoyu do cogo shablonu proyektuvannya Isnuye tri najposhirenishi formi vprovadzhennya zalezhnostej vprovadzhennya v konstruktor vprovadzhennya u vlastivist vprovadzhennya v metod Zmist 1 Oglyad 1 1 Perevagi 2 Struktura 2 1 UML klasi ta diagrama poslidovnosti 3 Prikladi 3 1 Bez vprovadzhennya zalezhnostej 3 2 Vprovadzhennya cherez konstruktor 3 3 Vprovadzhennya cherez vlastivist 3 4 Vprovadzhennya cherez metod 3 5 Konfiguruvannya cherez XML 3 5 1 Poperedzhennya 3 6 Konfiguruvannya programi za dopomogoyu kodu 4 Div takozh 5 PosilannyaOglyad red Vprovadzhennya zalezhnostej ce shablon proyektuvannya v yakomu zalezhnosti abo servisi vprovadzhuyutsya abo peredayutsya po posilannyu v zalezhnij ob yekt kliyent i stayut chastinoyu kliyentskogo stanu Shablon vidokremlyuye stvorennya zalezhnostej kliyenta vid vlasnoyi logiki kliyenta sho dozvolyaye komponentam buti slabko zv yazanimi i pritrimuvatisya principiv inversiyi zalezhnostej i yedinogo obov yazku Ce superechit anti shablonu service locator yakij dozvolyaye kliyentam znati pro sistemu sho vikoristovuyetsya dlya poshuku zalezhnostej Perevagi red Oskilki vprovadzhennya zalezhnostej ne vimagaye zmin u povedinci kodu jogo mozhna zastosuvati yak refaktoring V rezultati cogo kliyenti stayut bilsh nezalezhnimi i nad nimi legshe provoditi modulne testuvannya v izolyaciyi z vikoristannyam maketiv ob yekta yaki imituyut inshi ob yekti vid yakih zalezhit ob yekt sho testuyetsya Prostota testuvannya najchastishe ye pershoyu pomitnoyu perevagoyu vikoristannya vprovadzhennya zalezhnostej Vprovadzhennya zalezhnostej ne vimagaye vid kliyenta znan pro konkretnu realizaciyu yaku jomu potribno vikoristovuvati Ce dozvolyaye izolyuvati kliyent vid vplivu zmin proyektuvannya i defektiv Ce spriyaye povtornomu vikoristannyu testuvannyu i pidtrimci kodu Vprovadzhennya zalezhnostej mozhe vikoristovuvatisya dlya perenesennya detalej konfiguraciyi sistemi v konfiguracijni fajli sho dozvolyaye sistemi zminyuvati konfiguraciyu bez perekompilyaciyi Okremi konfiguraciyi mozhut buti napisani dlya riznih situacij sho vimagayut riznih realizacij komponentiv Vprovadzhennya zalezhnostej spriyaye paralelnij i nezalezhnij rozrobci Dva rozrobnika mozhut nezalezhno stvoryuvati klasi yaki vikoristovuyut odin odnogo znayuchi tilki pro interfejsi cherez yaki klasi spivpracyuyut Vprovadzhennya zalezhnostej znizhuye zv yaznist mizh klasom i jogo zalezhnostyami Struktura red UML klasi ta diagrama poslidovnosti red nbsp Priklad UML klasu ta diagrami poslidovnosti shablonu proyektuvannya Vprovadzhennya ZalezhnostejV navedenij vishe UML diagrami klasiv klas Client yakij potrebuye ob yekti ServiceA ta ServiceB ne instanciyuye klasi ServiceA1 ta ServiceB1 napryamu Zamist cogo klas Injector stvoryuye ob yekti ta vprovadzhuye yih v Client sho robit Client nezalezhnim vid togo yak ci ob yekti stvoryuyutsya yakij konkretno klas instanciyuyetsya UML diagrama poslidovnosti demonstruye vzayemodiyi chasu vikonannya Ob yekt Injector stvoryuye ob yekti ServiceA1 ta ServiceB1 Pislya cogo Injector stvoryuye ob yekt Client i vprovadzhuye v nogo ob yekti ServiceA1 ta ServiceB1 Prikladi red Bez vprovadzhennya zalezhnostej red V nastupnomu C prikladi klas Client mistit v sobi pole klasu Service yake inicializuyetsya v konstruktori klasu Client Kliyent maye kontrol nad tim yaka realizaciya servisa vikoristovuyetsya oskilki sam stvoryuye yiyi V comu prikladi kliyent maye zhorstku zalezhnist vid ServiceExample An example without dependency injection public class Client Internal reference to the service used by this client private readonly Service service Constructor public Client Specify a specific implementation in the constructor instead of using dependency injection service new ServiceExample Method within this client that uses the services public string Greet return Hello service Name Vprovadzhennya cherez konstruktor red Klas yakomu potribna zalezhnist povinen nadati vidkritij konstruktor yakij prijmaye ekzemplyar neobhidnoyi zalezhnosti yak argument konstruktora U bilshosti vipadkiv ce povinen buti tilki public konstruktor Yaksho neobhidna bilsh nizh odna zalezhnist mozhut buti vikoristani dodatkovi argumenti konstruktora Ye najbilsh shiroko vzhivanim i rekomendovanim metodom vprovadzhennya zalezhnostej public class Client private readonly IService service Constructor public Client IService service if service null throw new ArgumentNullException service service service Method within this client that uses the services public string Greet return Hello service Name Vprovadzhennya cherez vlastivist red Klas yakij vikoristovuye zalezhnist povinen nadati vidkritu dostupnu dlya zapisu vlastivist tipu zalezhnosti Client zalezhit vid IService Kliyenti mozhut postavlyati realizaciyi IService vstanovlyuyuchi vlastivist Dependency Na vidminu vid vprovadzhennya v konstruktor vi ne mozhete vidznachiti pole vlastivosti Dependency yak readonly tomu sho vi dozvolyayete viklikayuchim elementam zminyuvati cyu vlastivist v bud yakij moment zhittyevogo ciklu Client Odnak taka realizaciya ye krihkoyu tomu sho nemaye garantiyi sho vlastivist Dependency povertaye ekzemplyar IService Kod yak cej vikine NullReferenceException yaksho znachennya vlastivosti Dependency null public class Client public IService Dependency get set Method within this client that uses the services public string Greet return Hello Dependency Name Vprovadzhennya cherez metod red Element sho viklikaye metod vprovadzhuye zalezhnist yak parametr metodu v kozhen viklik metodu Vprovadzhennya v metod krashe vikoristovuvati todi koli zalezhnist mozhe zminyuvatisya z kozhnim viklikom metodu Ce mozhe buti v tomu vipadku koli zalezhnist sama po sobi predstavlyaye znachennya abo koli element sho viklikaye nadaye spozhivachevi informaciyu pro kontekst v yakomu viklikayetsya operaciya public class Client Method within this client that uses the services public string Greet IService service if service null throw new ArgumentNullException service return Hello service Name Konfiguruvannya cherez XML red Konfiguruvannya DI kontejneru Unity za dopomogoyu XML lt register type IBasketService mapTo BasketService gt lt register type BasketDiscountPolicy mapTo RepositoryBasketDiscountPolicy gt lt register type BasketRepository mapTo SqlBasketRepository gt lt constructor gt lt param name connString gt lt value value CommerceObjectContext typeConverter ConnectionStringConverter gt lt param gt lt constructor gt lt register gt lt register type DiscountRepository mapTo SqlDiscountRepository gt lt constructor gt lt param name connString gt lt value value CommerceObjectContext typeConverter ConnectionStringConverter gt lt param gt lt constructor gt lt register gt lt register type ProductRepository mapTo SqlProductRepository gt lt constructor gt lt param name connString gt lt value value CommerceObjectContext typeConverter ConnectionStringConverter gt lt param gt lt constructor gt lt register gt lt register type CurrencyProvider mapTo SqlCurrencyProvider gt lt constructor gt lt param name connString gt lt value value CommerceObjectContext typeConverter ConnectionStringConverter gt lt param gt lt constructor gt lt register gt Peretvorennya interfejsu IBasketService v klas BasketService realizuyetsya za dopomogoyu prostogo elementa register Deyaki konkretni klasi prijmayut ryadok z yednannya yak vhidni dani tomu neobhidno viznachiti yakim chinom znahoditsya znachennya cogo ryadka Sho stosuyetsya Unity mozhna zrobiti ce vkazavshi sho vi vikoristovuyete koristuvackij tip konvertera pid nazvoyu ConnectionStringConverter Cej konverter bude shukati znachennya CommerceObjectContext sered standartnih ryadkiv z yednannya web config i povertati ryadok z yednannya z cim im yam Reshta elementiv povtoryuyut ci dva paterni Oskilki Unity mozhe avtomatichno peretvoryuvati zapiti v konkretni tipi navit yaksho vidsutni yavni reyestraciyi vam ne potribno zastosovuvati XML elementi dlya HomeController i BasketController Zavantazhennya konfiguraciyi v kontejner vikonuyetsya za dopomogoyu vikliku yedinogo metodu container LoadConfiguration Poperedzhennya red Yak tilki vash zastosunok isp bude virostati v rozmirah i uskladnyuvatisya tezh same bude vidbuvatisya i z vashim konfiguracijnim fajlom yaksho vi vikoristovuyete konfiguracijnu kompoziciyu Vin mozhe stati spravzhnoyu problemoyu oskilki cej fajl modelyuye taki sutnosti kodu yak klasi parametri tosho ale bez perevag kompilyatora opcij nalagodzhennya i t d Fajli budut stavati krihkimi i neprozorimi z tochki zoru nayavnosti pomilok tomu vikoristovujte danij pidhid tilki yaksho vam neobhidno piznye zv yazuvannya Konfiguruvannya programi za dopomogoyu kodu red c For lt IBasketService gt Use lt BasketService gt c For lt BasketDiscountPolicy gt Use lt RepositoryBasketDiscountPolicy gt string connectionString ConfigurationManager ConnectionStrings CommerceObjectContext ConnectionString c For lt BasketRepository gt Use lt SqlBasketRepository gt Ctor lt string gt Is connectionString c For lt DiscountRepository gt Use lt SqlDiscountRepository gt Ctor lt string gt Is connectionString c For lt ProductRepository gt Use lt SqlProductRepository gt Ctor lt string gt Is connectionString c For lt CurrencyProvider gt Use lt SqlCurrencyProvider gt Ctor lt string gt Is connectionString Dlya togo shob pidtrimati ti klasi dlya yakih potriben ryadok z yednannya vi prodovzhuyete poslidovnist For Use shlyahom vikliku metodu Ctor ta peredachi ryadka z yednannya Metod Ctor vikonuye poshuk strokovogo parametra v konstruktori konkretnogo klasu i vikoristovuye peredane znachennya dlya cogo parametra Vikoristannya kodu yak konfiguraciyi ne tilki kompaktnishe XML konfiguraciyi ale takozh pidtrimuyetsya kompilyatorom Tipi argumentiv yavlyayut soboyu realni tipi yaki pereviryaye kompilyator Zminna API StructureMap postavlyayetsya navit z deyakimi vidovimi obmezhuvachami yaki povidomlyayut kompilyatoru pro perevirku togo chi zbigayetsya tip yakij viznachayetsya metodom vikoristannya z abstrakciyami poznachenimi za dopomogoyu metodu For Yaksho peretvorennya nemozhlivo to kod ne kompilyuyetsya Nezvazhayuchi na te sho tehnologiya vikoristannya kodu yak konfiguraciyi bezpechna i prosta v zastosuvanni yiyi potribno bilshe suprovodzhuvati Shorazu pri dodavanni u zastosunok novogo tipu vi takozh povinni pam yatati i pro jogo reyestraciyu Div takozh red Inversiya keruvannya Princip inversiyi zalezhnostejPosilannya red Dependency Injection in NET Arhivovano 27 chervnya 2015 u Wayback Machine Mark Seemann Manning 2011 Inversion of Control Containers and the Dependency Injection pattern Arhivovano 12 travnya 2020 u Wayback Machine Martin Fowler Design Patterns Dependency Injection MSDN Magazine September 2005 Otrimano z https uk wikipedia org w index php title Vprovadzhennya zalezhnostej amp oldid 39211944