Evgenii Legotckoi
Evgenii Legotckoi20 сентября 2018 г. 9:33

Порождающие шаблоны проектирования - Синглтон

Цели

  1. Убедиться, что класс имеет только один экземпляр и предоставляет глобальную точку доступа к нему.
  2. Инкапсулированная "инициализация в определённый момент времени" или "инициализация при первом использовании".

Проблематика

Приложению нужен один и только один экземпляр объекта. Кроме того, необходимы ленивая инициализация и глобальный доступ.


Обсуждение

Сделать класс объекта ответственным за создание одного единственного экземпляра, его инициализацию, доступ и принудительное выполнение. Объявить экземпляр как частный статический элемент данных. Предоставить публичную статическую функцию-член, которая инкапсулирует весь код инициализации и обеспечивает доступ к экземпляру.

Клиент обращается к функции доступа (используя имя класса и оператор разрешения области), когда требуется ссылка на синглетон объект.

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

  • Владение одним экземпляром не может быть разумно назначено каким-либо объектам
  • Желательна ленивая инициализация
  • Глобальный доступ не предусмотрен

Если одно из условий не выполняется, то Синглтон не особо интересен.

Шаблон Singleton можно расширить для поддержки доступа к количеству экземпляров, зависящих от приложения.

Структура

Сделайте класс Singleton экземпляра ответственным за доступ и «инициализацию при первом использовании». Единственный экземпляр - это частный статический атрибут. Функция доступа является общедоступным статическим методом.

Пример

Шаблон Singleton гарантирует, что класс имеет только один экземпляр и предоставляет глобальную точку доступа к этому экземпляру. Он назван в честь одноэлементного набора, который определяется как набор, содержащий один элемент. Канцелярией президента Соединенных Штатов является Синглетон. Конституция Соединенных Штатов определяет средства, с помощью которых избирается президент, ограничивает срок полномочий и определяет порядок правопреемства. В результате в любой момент может быть не более одного действующего президента. Независимо от личности действующего президента, название «Президент Соединенных Штатов» является глобальной точкой доступа, которая идентифицирует человека в офисе.

Контрольный список

  1. Определите частный статический атрибут в классе «Сиглтона».
  2. Определите публичную функцию статического доступа в классе.
  3. Сделайте «ленивую инициализацию» (создание при первом использовании) в функции доступа.
  4. Определите все конструкторы как private или protected.
  5. Клиенты могут использовать только функцию доступа для работы с Singleton.

Эмпирические правила

  • Abstract Factory, Builder и Prototype могут использовать Singleton в своей реализации.
  • Объекты фасада часто являются синглтонами, потому что требуется только один объект Facade.
  • Объекты состояния часто являются синглтонами.
  • Преимущество Singleton над глобальными переменными заключается в том, что вы абсолютно уверены в количестве экземпляров, когда используете Singleton, и можете также изменить код, чтобы управлять любым количеством экземпляров.
  • Шаблон проектирования Singleton является одним из наиболее неуправляемых шаблонов. Синглтоны предназначены для использования, когда класс должен иметь ровно один экземпляр, не более, не меньше. Разработчики часто используют Singletons в ошибочной попытке заменить глобальные переменные. Синглтон не покончит с глобальными переменными; он просто переименовывает их.
  • Когда Синглтон не нужен? Короткий ответ: большую часть времени. Длинный ответ: когда проще передать ресурс объекта в качестве ссылки на объекты, которые в нем нуждаются, а не позволять объектам обращаться к ресурсу глобально. Реальная проблема с Singleton заключается в том, что они дают вам такое хорошее оправдание, чтобы не думать о соответствующей видимости объекта. Поиск правильного баланса экспозиции и защиты объекта имеет решающее значение для поддержания гибкости кода
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
ОК

Qt - Тест 001. Сигналы и слоты

  • Результат:47баллов,
  • Очки рейтинга-6
A
  • Alena
  • 19 января 2025 г. 11:41

C++ - Тест 005. Структуры и Классы

  • Результат:58баллов,
  • Очки рейтинга-2
OI
  • Ora Iro
  • 24 декабря 2024 г. 6:38

C++ - Тест 001. Первая программа и типы данных

  • Результат:40баллов,
  • Очки рейтинга-8
Последние комментарии
ИМ
Игорь Максимов22 ноября 2024 г. 11:51
Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi31 октября 2024 г. 14:37
Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 октября 2024 г. 8:19
Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов5 октября 2024 г. 7:51
Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55 июля 2024 г. 11:02
QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Сейчас обсуждают на форуме
n
nkly3 января 2025 г. 2:52
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
Marsel16 августа 2023 г. 14:26
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii Legotckoi24 июня 2024 г. 15:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey115 ноября 2024 г. 6:04
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProject4 июня 2022 г. 3:49
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

Следите за нами в социальных сетях