Несколько слов о Dependency Injection

В реальных приложениях практически каждый класс имеет немалое число зависимостей — других классов, на которые он рассчитывает для осуществления своих задач. Эти зависимости, в свою очередь, могут зависеть от других классов, и т.д.

В результате может получится достаточно большое и сложное дерево зависимостей, которое, если неправильно с ним работать, существенно осложнит понимание логики работы класса, тестирование и отладку.

И здесь на помощь приходит паттерн Dependency Injection, или, сокращенно, DI.

В чем его суть?

Всё очень просто — все зависимости какого-то класса ему явно предоставляет некоторый внешний механизм, который обычно называется DI-контейнером.

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