@PTPPAction · Post #1905 · 05.05.2024 г., 07:05
#dev#IITII#merged fix(search): mt 搜索问题 #1822 #1829
TGINSIGHT SIMILAR POSTS
Изходен канал @clockstackwheels · Post #973 · 20.04
В C# есть модификатор доступа internal, который закрывает свойство или метод для всего, кроме текущей сборки (сборка это по сути группа пространств имён). И это чертовски удобно для построения правильной архитектуры по DDD — ты делаешь домен отдельной сборкой без внешних зависимостей, у сущностей закрываешь сеттеры и другие поля модификатором internal, а бизнес-правила с открытыми методами уже пишешь в агрегатах, которые содержат эти сущности. Агрегаты объявлены в той же сборке, так что они могут с сущностями делать что угодно, но слой приложения уже сможет вызвать только метод агрегата. Пример. Есть бизнес-процесс, который включает в себя две сущности: письмо и прикреплённый к нему документ. У каждой из этих сущностей разные жизненные циклы, но письмо можно отправить только в том случае, если статус документа "Согласован". Мы делаем агрегат "письмо с документом" и там public-метод отправки письма сначала проверяет статус документа, а потом вызывает internal-метод отправки в сущности письма. Снаружи (вне домена) вызвать сразу отправку письма невозможно. Но как эту задачу решают разработчики на других языках? Я совершенно не понимаю, как сделать хорошую архитектуру без internal. Окей, в некоторых языках вообще нет вменяемого ОПП и системы типов, но и к таким ребятам я бы не подходил с вопросами об энтерпрайз-архитектуре. Однако, многие серьёзные проекты пишутся на Java или, скажем, Go, что делают разработчики там? Может, кто-нибудь знает, и расскажет мне в комментариях? #dev
Hashtags
Общо глобално търсене
@PTPPAction · Post #1905 · 05.05.2024 г., 07:05
#dev#IITII#merged fix(search): mt 搜索问题 #1822 #1829
@PTPPAction · Post #1902 · 05.05.2024 г., 06:35
#dev#IITII#merged fix(audiences):修复做种数、做种体积、发种数获取 (#1827)
@PTPPAction · Post #1899 · 05.05.2024 г., 06:00
#dev#IITII#merged fix(msg): 不统计禁用消息通知站点
@PTPPAction · Post #1859 · 19.04.2024 г., 06:50
#dev#IITII#merged fix(jpop): uploads count & snatches count
@PTPPAction · Post #1856 · 18.04.2024 г., 14:45
#dev#IITII#merged refactor: 基于 Common 模板重写 GTru 和 GTorg (#1813)
@PTPPAction · Post #1851 · 18.04.2024 г., 07:25
#dev#IITII#merged fix(ecust):site update seedingPoints (#1810)
@PTPPAction · Post #1838 · 14.04.2024 г., 06:20
#dev#IITII#merged fix(qingwa): bouns alias and level name (#1804)
@PTPPAction · Post #1831 · 11.04.2024 г., 11:45
#dev#IITII#merged feat: RuTracker (all), TT (search), LC (search), AN (search) (#1801)
@PTPPAction · Post #1828 · 11.04.2024 г., 11:40
#dev#IITII#merged fix(mt): 详情页下载 #1762 #1799
@PTPPAction · Post #1821 · 09.04.2024 г., 07:50
#dev#IITII#merged fix(mt): 数据显示问题 #1762 #1796
@PTPPAction · Post #1818 · 08.04.2024 г., 14:10
#dev#IITII#merged fix(mt): 用户数据刷新成功但是显示失败 #1762
@PTPPAction · Post #1815 · 08.04.2024 г., 13:55
#dev#IITII#merged fix(mt): 历史数据丢失问题 #1762 #1785