Несколько слов о Dependency Injection
В реальных приложениях практически каждый класс имеет немалое число зависимостей — других классов, на которые он рассчитывает для осуществления своих задач. Эти зависимости, в свою очередь, могут зависеть от других классов, и т.д.
В результате может получится достаточно большое и сложное дерево зависимостей, которое, если неправильно с ним работать, существенно осложнит понимание логики работы класса, тестирование и отладку.
И здесь на помощь приходит паттерн Dependency Injection, или, сокращенно, DI.
В чем его суть?
Всё очень просто — все зависимости какого-то класса ему явно предоставляет некоторый внешний механизм, который обычно называется DI-контейнером.
Преимущества такого подхода очевидны: • Управление зависимостями вынесено во внешний класс, S из SOLID; • Все зависимости явно описываются и можно легко понять, что к чему относится; • При предоставлении зависимостей контейнер может легко их подменить для того, чтобы подставить mock/stub классы для тестирования; • Сильно понижается связанность классов, что ведёт к более чистому коду.