менее хочется понять чёткие границы с принципом единой ответственности.
Почитал несколько статей но чёткого ответа я пока не нашёл как же взглянув в класс ясно увидить что некоторые методы нарушают этот принцип
В случае когда класс называется к примеру Time а он рассчитывает сумму НДС покупки все ясно (тут этот принцип жестко нарушается) .
Но ведь бывает же и менее очивидные примеры.
Например вот у меня есть в блоге посты, у каждого поста обязательно должна быть картинка, с одной стороны методы по добавлению удалению картинки хочется сделать прям в классе Post, с другой стороны внутри что то подсказывает выноси работу с картинками в отдельный класс.
И пока что создаётся диссонанс, вроде как метод косвенно касается класса, но вроде как его нужно вынести в другой(класс) и появляются вопросы а почему тогда не стоит выносить в отдельный класс title, description, content, а во второй класс работу с категориями поста, в третий класс теги поста.
Как определить чётко границы когда переносить в другой класс а когда оставлять?
то что ты спрашиваешь, это больше про LoD
t.me/oop_ru вам лучше сюда
Просто глянуть - никак. Надо анализировать как модуль меняется
А если тебя завтра скажут новую бизнес модель создать с возможностью загрузки картинок, и потом ещё к одной прикрутить? . Если у тебя есть отдельный модуль для работы с изображениями, то его легко переиспользовать
Обсуждают сегодня