[Новичок] PHP OOP появились сомнения. Что делать и как быть? Приветствую разработчиков!
Довольно давно занимаюсь программированием на PHP, но некоторое время назад попробовал Java, а затем C# и был в восторге от ООП и строгой типизации. Оттого и решил заняться "подтягиванием" знаний, решил так сказать, попробовать ООП в PHP. И вроде как даже получается, основные концепции ООП вроде как понимаю, паттерны так же, но со временем начали появляться вопросы с тем правильно ли я делаю или нет, знакомых гуру у меня нет поэтому решил попытаться с сообществом тостера.
1) Правильно ли это утверждение "не стоит применять паттерны абсолютно везде где пахнет малейшим ООП"?
2) Правильно ли для каждой элементарной сущности будь то комментарий, пост или пользователь создавать отдельный объект Comment, Post, User или File которые будут содержать в себе какую либо информацию для использования в обработчике. Например User в качестве аргумента конструктора AuthHandler или File в качестве аргумента одного из методов ImageHandler?
3) Сколько максимально стоит использовать аргументов для конструктора и для методов (чтобы было читабельно и "правильно")?
4) Правильно ли использовать связку менеджер базы данных -> элементарная сущность для каждой такой сущности: Например: class UserManager extends Db и class User (конструктор принимает UserManager и распихивает по полям данные. Ну или сама по себе сущность File в которую можем запихнуть бинарные данные (тут мы не ведем речь о базе данных)

21 Авг 2019 в 07:03
208 +1
0
Ответы
1

1) Не стоит применять паттерны абсолютно везде, где пахнет малейшим ООП. Паттерны следует использовать тогда, когда они действительно помогают решить конкретную задачу или проблему. Иногда их применение может быть излишним и усложнить код.

2) Создание отдельного объекта для каждой элементарной сущности (комментарий, пост, пользователь и т.д.) может быть хорошим решением, если это помогает структурировать код и лучше организовать данные. Однако не стоит злоупотреблять этим подходом, чтобы избежать избыточности и излишней сложности.

3) Количество аргументов для конструктора и методов должно быть разумным. Идеально, чтобы конструктор принимал не более 3-4 аргументов, чтобы код был читабельным и понятным. Аргументы методов также следует ограничивать, чтобы не усложнять вызовы и поддержку кода.

4) Использование связки менеджера базы данных -> элементарная сущность (например, класс UserManager и класс User) может быть хорошим подходом для организации работы с базой данных и данных. Однако стоит быть внимательным, чтобы не нарушать принцип единственной ответственности и не делать классы слишком зависимыми друг от друга.

20 Апр 2024 в 13:08
Не можешь разобраться в этой теме?
Обратись за помощью к экспертам
Название заказа не должно быть пустым
Введите email
Бесплатные доработки
Гарантированные бесплатные доработки
Быстрое выполнение
Быстрое выполнение от 2 часов
Проверка работы
Проверка работы на плагиат
Интересные статьи из справочника
Поможем написать учебную работу
Название заказа не должно быть пустым
Введите email
Доверьте свою работу экспертам
Разместите заказ
Наша система отправит ваш заказ на оценку 96 340 авторам
Первые отклики появятся уже в течение 10 минут
Прямой эфир