О синглтоне

Ну, я читал, что синглтоны плохи, потому что они против паттернов. Я также читал, что главной причиной этого является глобальная ссылка на синглтон, так или иначе:

Всегда ли можно избежать синглтона?

Если да, скажем, например, я получил сеть IOCP, и мне нужно ее инициализировать один раз, и этот объект должен быть постоянным на протяжении всего срока службы программного обеспечения. То же самое происходит с классом, который я назвал "рисовать", где я печатаю данные на экран. Если бы я не сделал ни одного из них, мне все равно понадобилась бы глобальная переменная текущего Hwnd и для локальной инициализации объекта каждый раз, когда я собираюсь его использовать (это действительно раздражает).

Таким образом, использование синглтона является признаком того, что мой дизайн является недостатком? Что я могу сделать, чтобы избежать их?

Благодарю.

2 ответа

Всегда ли можно избежать синглтона?

Да, используйте глобальную переменную или (что еще лучше) исправьте свой дизайн. Один из вариантов исправить дизайн - это использовать некоторую инверсию управления.

Если вы попытаетесь использовать принципы ОО, вы увидите, что можете обойтись без единого.

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

Если объекты, которым требуется доступ к этому ресурсу, могут быть созданы с помощью этого ресурса (IOC, внедрение зависимостей), то это лучший путь, таким образом сохраняя простоту и избегая создания Singleton. Поцелуй

Если по какой-либо причине существуют сущности, которым нужен доступ к ресурсу, но которые не могут быть созданы с его помощью, то должна быть реализована альтернатива. Одним из вариантов является Singleton, но другим вариантом, который мне нравится использовать, является Factory. Это полностью инкапсулирует создание ресурса и является гораздо более ориентированным на будущее, что означает, что если в будущем по какой-либо причине может быть создан более одного экземпляра ресурса, то все его инкапсулируются. Вы не можете / не должны пытаться сделать это с помощью Singleton. Конечно, внутренне фабрика будет поддерживать уникальный экземпляр ресурса.

Есть те, которые утверждают, что если объект не может быть создан с помощью ресурса, то дизайн плохой. С этим можно поспорить, и, вероятно, это следует делать в каждом конкретном случае.

Другие вопросы по тегам