конструкторов?
1. Там, где надо предзадать параметры. 2. Там, где ты не контролируешь создание объекта. (ограничение new в женериках мега тормознутое)
Есть у тебя скажем класс User. Есть у него свойство PasswordHash. И тут у тебя 3 стула - либо делаешь ему публичный сеттер и в местах, где его надо создать с хэшом - носишь с собой хэшилку. Либо зааязываешь конструктор изнутри на конкретную имплементацию хэшилки (передаешь пароль в конструктор, внутри которого зовётся хэшилка, ну либо немного измененный вариант - передать в конструктор ещё и интерфейс хэшилки и позвать её там). Но хэшилка это сугубо инфраструктурный сервис, а User - доменный объект. Если попробуешь вынести домен в отдельную сборку, то получается Либо он должен зависеть от интерфейсов инфраструктурной сборки (что как бы рак полный), либо включать в себя интерфейсы некоторых утилитарных классов. И есть третий путь - делаешь фабрику, зависящую от интерфейса хэшилки и полностью развязываешь свой конструктор и домен от способа хэширования. А там где надо создавать юзера - просовываешь интерфейс фабрики, а саязываешь всё воедино на уровне IoC контейнера.
Обсуждают сегодня