Как правильно применять Liskov Substitution Principle в реальном Java/Spring проекте?

JavaMiddleOOP и проектирование на JavaПрактикаjava|oop и проектирование на java|liskov|liskov substitution principle

Что хотят услышать интервьюеры:

Практический подход: используйте Liskov Substitution Principle там, где он решает конкретную задачу, а не ради моды.

  • Определите слой: domain, application, infrastructure или API.
  • Проверьте влияние на транзакции, потокобезопасность, тесты и поддержку.
  • Зафиксируйте контракт через тест или явно описанный API.

Ответ:

На собеседовании: сильный ответ показывает trade-off и production-последствия. Риск: создавать подкласс, который бросает UnsupportedOperationException там, где базовый контракт обещает операцию.

List<Number> numbers = new ArrayList<>();

Источники

Похожие вопросы