212 похожих чатов

Геттеры / сеттеры - имеются ввиду для классов, являющихся сущностями

(entities)?

я считаю что разумно оставить только геттеры (только тех полей, имеющих смысл в бизнес-логике: какие-то служебные для внутренних нужд, хотя они редко встречаются в сущностях, должны остаться скрытыми), как паттерн контроля над мутациями

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

7 ответов

4 просмотра

Плохо это. Обычно когда достали с базы сущность то ни кто не лочит ответствующий строку в базе. Тоесть мы получаем устаревшие данные потенциально. Далее раз там гетеры то мы используем УСТАРЕВШИЕ данные для логики а значит ломаем логику и получаем баги. Плюс такой себе глобальный стейт Кто угодно где угодно может достать сущность из репы условной и получить доступ к стейту. Таким образом база как глобальный стейт для всего приложения. Хотя почему то при этом люди избегают глобальных переменных хотя это по сути одно и тоже получается.

Тесно связана если для одной бизнес операции начинаем использовать несколько сущностей то все приехали лочить их ни кто не будет а баги делать будут А если нет акцессоров то и использовать больше одной за раз не получится

Sergei Baikin
Тесно связана если для одной бизнес операции начин...

Что-то не понятно. Для одной бизнес операции необходимо использоать несколько сущностей, вы написали есть проблема устаревания данных. Ответ - не использовать несколько сущностей, это как? Если в операции уже есть необходимость в переплетения данных, судя по ТЗ.

Павел Г.
Что-то не понятно. Для одной бизнес операции необх...

Разбиваем операцию на минимальные операции где мгновенное и отложенное согласование данных. Далее всё что мгновенное должно жить внутри одной капсулы/акторе и в ней работать. Всё остальное просто делается паралельно или последовательно через сообщения. Тест получаем набор операций изолированных с немедленной согласасованностью связанные отложенной согласованностью

Блья-✖️➕➖➗ Автор вопроса

Имеется в виду транзакция для того, что вы называете капсулой. Для остальных капсул уже свои транзакции

Блья ✖️➕➖➗
Имеется в виду транзакция для того, что вы называе...

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

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

Обсуждают сегодня

коллеги привет. уже второй день бьемся об заклад с одной ошибкой, может вы сталкивались с таки странным поведением? есть тестовый сервер, на который паблишим релизную версию W...
Magzhan
11
Комрады, посоветуйте, куда копать? Стал прикручивать кастомизацию тем. В OnShow главной главной формы пытаюсь загрузить из файла настроек и применить тему (на скрине, как долж...
Ed Doc
13
Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
OnShow один раз вызывается? или возможен Hide?
Iluha Companets
14
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Всем привет, на линуксе лучше на fasm или nasm учиться писать для начала ?
meszjol
14
Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
🥹сениоры нужна помощь. Столкнулся с интересным. Сайт на 1.4 весь в вирусах. Просканировал почистил вроде. Можно конечно скачать развернуть на опенсервере, но пока пробую на ко...
Alexander Grishin 👽
3
Карта сайта