Projektuję nowy system i chcę wiedzieć, czym jest inwersja kontroli (MKOl), a co ważniejsze, kiedy z niej korzystać.
Czy to musi być zaimplementowane z interfejsami czy może być zrobione z klasami?
design
design-patterns
inversion-of-control
Upiorny mistrz Jedi
źródło
źródło
Odpowiedzi:
IoC (patrz Inwersja kontroli na Wikipedii) ma zastosowanie w przypadkach, w których składnik nie może wykonać zadania całkowicie, ponieważ nie ma niezbędnych informacji ani funkcji.
Najprostszym przykładem wzorca IoC są funkcje zwrotne w C. Na przykład możesz zadeklarować funkcję:
Która iteruje po
list
zastosowaniuf
funkcji do każdego z jej elementów.Iterator
Funkcja nie wie, w jaki sposób każdy element zostanie przetworzony, po prostu zapewnić funkcję jako argument, i przetwarza je.Jak pokazuje poprzedni przykład, IoC pozwala rozdzielić program na osobne komponenty, które się nie znają. Jedną z najpopularniejszych wersji IoC jest Dependecy Injection .
W przypadku wstrzykiwania zależności każdy komponent musi zadeklarować listę zależności wymaganych do wykonania swojego zadania. W czasie wykonywania specjalny komponent (ogólnie) o nazwie kontener IoC wykonuje wiązanie między tymi komponentami. Próbuje podać wartości dla opublikowanych zależności komponentów.
Oto przykład w pseudokodzie:
W tym przykładzie klasa
Foo
ma konstruktor, który wymaga argumentu typu,Boo
aby wykonać jakąś akcję.Możesz utworzyć instancję klasy
Foo
za pomocą kodu podobnego do tego:MyContainer
- jest kontenerem IoC , który dba o uzyskanie instancjiBoo
i przekazanie jej doFoo
konstruktora.Podsumowując, IoC pozwala rozdzielić program na osobne części. Jest to dobre, ponieważ:
Jednak w niektórych przypadkach IoC może utrudniać zrozumienie kodu.
Jeśli chcesz zobaczyć dobry przykład użycia świata rzeczywistego z IoC , rzucić okiem na Mircosoft Composite UI Application bloku i CompositeWPF
Mam nadzieję, że moje wyjaśnienie ci pomoże.
Pozdrawiam,
jang
źródło
Ponieważ ostatnio sam się w to zagłębiłem i zachowałem wszystkie zakładki, poniższe informacje okazały się nieocenione przy poznawaniu IOC / DI.
Martin Fowlers Artykuł oryginalny na temat MKOl / DI
Kilka pojęć, które należy znać jako pierwsze
Doskonały zbiór samouczków IOC / DI
Rezerwuj na IOC / DI From Manning Press
Źródło i wyjaśnienie, jak stworzyć własny MKOl - ponieważ czytanie kodu źródłowego jest zawsze najlepszym sposobem na zrozumienie pojęcia.
źródło
Hej JMS, w zasadzie IoC / DI pozwoli ci zdefiniować implementację, której używasz raz, i zachowaj statyczną kopię swojego kontenera, aby odwoływała się za każdym razem, gdy chcesz się do niego odwoływać.
Wikipedia prawdopodobnie ci pomoże, ale chciałem odnieść się do twojej drugiej części - tak, wstrzyknięcie zależności można wykonać dla klas (tj. Za każdym razem, gdy ten typ klasy musi zostać przekazany do metody, użyj tej klasy), ale lepiej jest używaj interfejsów, ponieważ w ten sposób możesz zmienić wersję dostawcy, repozytorium itp., której używasz, po prostu odwołując się do niego w konfiguracji.
IE, powiedzmy, że masz interfejs do odczytu strumienia, a także implementację XMLStreamReader i SQLStreamReader. Następnie możesz przekazać odniesienie do interfejsu do swoich metod, a następnie w kontenerze IoC powiedz, którego użyć.
Tak więc możesz mieć publiczną listę ReadPeople (czytnik IStreamReader), aw swojej konfiguracji kontenera IoC powiedz to za każdym razem, gdy spodziewasz się, że IStreamReader używa SQLStreamReader.
Następnie, jeśli zmienisz zdanie później, musisz go zmienić tylko w jednym miejscu (konfiguracja kontenera) i nie będzie miało znaczenia, ile metod poprosi o IStreamReader, zawsze uzyska domyślną wartość, o której kazałeś kontenerowi Podaj, podac, zaserwowac.
źródło
Załóżmy, że masz walidator do sprawdzania, czy firma jest ważna w twoim systemie. Twój „BusinessValidator” może mieć pole typu AddressValidator, które weryfikuje adresową część firmy. Jeśli chcesz przetestować BusinessValidator bez wykonywania kodu zewnętrznego (tj. Kodu addressValidator), to jeśli użyłeś w swoim środowisku jakiegoś IoC / DI, możesz łatwo „wstrzyknąć” fałszywy adres Validator w jego miejsce i nie musisz się martwić o testowanie kod poza zakresem testowanej klasy.
źródło