@PTPPAction · Post #1166 · 06.10.2023 г., 16:45
#dev#fzlins#merged fix(Blu): completed status
TGINSIGHT SIMILAR POSTS
Изходен канал @clockstackwheels · Post #973 · 20.04
В C# есть модификатор доступа internal, который закрывает свойство или метод для всего, кроме текущей сборки (сборка это по сути группа пространств имён). И это чертовски удобно для построения правильной архитектуры по DDD — ты делаешь домен отдельной сборкой без внешних зависимостей, у сущностей закрываешь сеттеры и другие поля модификатором internal, а бизнес-правила с открытыми методами уже пишешь в агрегатах, которые содержат эти сущности. Агрегаты объявлены в той же сборке, так что они могут с сущностями делать что угодно, но слой приложения уже сможет вызвать только метод агрегата. Пример. Есть бизнес-процесс, который включает в себя две сущности: письмо и прикреплённый к нему документ. У каждой из этих сущностей разные жизненные циклы, но письмо можно отправить только в том случае, если статус документа "Согласован". Мы делаем агрегат "письмо с документом" и там public-метод отправки письма сначала проверяет статус документа, а потом вызывает internal-метод отправки в сущности письма. Снаружи (вне домена) вызвать сразу отправку письма невозможно. Но как эту задачу решают разработчики на других языках? Я совершенно не понимаю, как сделать хорошую архитектуру без internal. Окей, в некоторых языках вообще нет вменяемого ОПП и системы типов, но и к таким ребятам я бы не подходил с вопросами об энтерпрайз-архитектуре. Однако, многие серьёзные проекты пишутся на Java или, скажем, Go, что делают разработчики там? Может, кто-нибудь знает, и расскажет мне в комментариях? #dev
Hashtags
Общо глобално търсене
@PTPPAction · Post #1166 · 06.10.2023 г., 16:45
#dev#fzlins#merged fix(Blu): completed status
@PTPPAction · Post #1158 · 04.10.2023 г., 20:00
#dev#fzlins#merged fix(HDFans): status and progress
@PTPPAction · Post #1147 · 29.09.2023 г., 14:20
#dev#fzlins#merged fix(huno): level name and join time
@PTPPAction · Post #1144 · 29.09.2023 г., 12:00
#dev#fzlins#merged fix(HDCity): 使用架构获取做种数和做种量
@PTPPAction · Post #1141 · 29.09.2023 г., 10:30
#dev#fzlins#merged fix(bts):使用架构获取做种数和做种量
@PTPPAction · Post #1138 · 29.09.2023 г., 00:05
#dev#fzlins#merged fix(np): 旧版架构ipv6多重汇报导致做种数和做种量翻倍
@PTPPAction · Post #1135 · 28.09.2023 г., 14:55
#dev#fzlins#merged fix(UBits): 正确显示种子状态及进度
@PTPPAction · Post #1132 · 27.09.2023 г., 16:05
#dev#fzlins#merged fix(ab): average seedtime
@PTPPAction · Post #1126 · 24.09.2023 г., 11:55
#dev#fzlins#merged feat:搜索结果页面可选择标题中间省略
@PTPPAction · Post #1123 · 24.09.2023 г., 11:50
#dev#fzlins#merged fix(MT): UI rollback
@PTPPAction · Post #1118 · 23.09.2023 г., 21:50
#dev#fzlins#merged fix(MT): new UI
@PTPPAction · Post #1076 · 12.09.2023 г., 17:10
#dev#fzlins#merged add uploads for TNode