D в SOLID означает Принцип инверсии зависимостей (Dependency Inversion Principle - DIP).
Принцип гласит:
Суть DIP заключается в том, чтобы высокоуровневые политики не зависели напрямую от низкоуровневых реализаций. Вместо этого обе стороны должны зависеть от абстракций (интерфейсов или абстрактных классов).
Связь с интерфейсами:
Интерфейсы выступают в роли этих самых абстракций. Они определяют контракт, которому должна соответствовать конкретная реализация.
Пример без DIP:
php
В этом примере UserRepository (модуль верхнего уровня, представляющий бизнес-логику) напрямую зависит от MySqlConnection (модуль нижнего уровня, представляющий детали реализации). Если потребуется перейти на PostgreSQL, придется менять UserRepository.
Пример с DIP и использованием интерфейса:
php
В этом улучшенном примере UserRepository зависит от интерфейса DbConnectionInterface, а не от конкретной реализации. Это позволяет легко менять тип базы данных, передавая в конструктор UserRepository разные реализации этого интерфейса.
Таким образом, интерфейсы играют ключевую роль в реализации DIP, предоставляя абстракции, которые позволяют высокоуровневым модулям оставаться независимыми от низкоуровневых деталей реализации. Это повышает гибкость, тестируемость и поддерживаемость кода.