- 1. Голи
- 2. Проблеми
- 3. Обговорення
- 4. Структура
- 5. Приклад
- 6. Контрольний список
- 7. Емпіричні правила
Голи
- Переконатися, що клас має лише один екземпляр та надає глобальну точку доступу до нього.
- Інкапсульована "ініціалізація у певний момент часу" або "ініціалізація при першому використанні".
Проблеми
Додатку потрібен один і лише один екземпляр об'єкта. Крім того, необхідні лінива ініціалізація та глобальний доступ.
Обговорення
Зробити клас об'єкта відповідальним за створення єдиного екземпляра, його ініціалізацію, доступ і примусове виконання. Оголосити екземпляр як окремий статичний елемент даних. Надати публічну статичну функцію-член, яка інкапсулює весь код ініціалізації та забезпечує доступ до екземпляра.
Клієнт звертається до функції доступу (використовуючи ім'я класу та оператора роздільної здатності області), коли потрібне посилання на синглетон об'єкт.
Сінглтон слід розглядати тільки в тому випадку, якщо задовольняються всі три з наступних критеріїв: Власність одного екземпляра не може бути розумно призначена
- Володіння одним екземпляром не може бути розумно призначене будь-яким об'єктам
- Бажана лінива ініціалізація
- Глобальний доступ не передбачено
Якщо жодна з умов не виконується, то Сінглтон не дуже цікавий.
Можна розширити шаблон Singleton для підтримки доступу до кількості екземплярів, що залежать від програми.
Структура
Зробіть клас Singleton екземпляра відповідальним за доступ та "ініціалізацію при першому використанні". Єдиний екземпляр – це приватний статичний атрибут. Функція доступу є загальнодоступним статичним методом.
Приклад
Шаблон Singleton гарантує, що клас має лише один екземпляр та надає глобальну точку доступу до цього екземпляра. Він названий на честь одноелементного набору, що визначається як набір, що містить один елемент. Канцелярією президента Сполучених Штатів є Сінглетон. Конституція Сполучених Штатів визначає кошти, за допомогою яких обирається президент, обмежує термін повноважень та визначає порядок правонаступництва. У результаті будь-якої миті може бути не більше одного чинного президента. Незалежно від особи чинного президента назва «Президент Сполучених Штатів» є глобальною точкою доступу, яка ідентифікує людину в офісі.
Контрольний список
- Визначте приватний статичний атрибут у класі "Сіглтона".
- Визначте публічну функцію статичного доступу у класі.
- Зробіть "ліниву ініціалізацію" (створення при першому використанні) у функції доступу.
- Визначте всі конструктори як private чи protected.
- Клієнти можуть використовувати лише функцію доступу до роботи з Singleton.
Емпіричні правила
- Abstract Factory, Builder і Prototype можуть використовувати Singleton у своїй реалізації.
- Об'єкти фасаду часто є синглтонами, тому що потрібно лише один об'єкт Facade.
- Об'єкти стану часто є синглтонами.
- Перевага Singleton над глобальними змінними полягає в тому, що ви абсолютно впевнені в кількості екземплярів, коли використовуєте Singleton, і можете також змінити код, щоб керувати будь-якою кількістю екземплярів.
- Шаблон проектування Singleton є одним із найбільш некерованих шаблонів. Синглтони призначені для використання, коли клас повинен мати рівно один екземпляр, не більше, не менше. Розробники часто використовують Singletons у помилковій спробі замінити глобальні змінні. Сінглтон не покінчить з глобальними змінними; він просто перейменовує їх.
- Коли Сінглтон не потрібен? Коротка відповідь: більшу частину часу. Довга відповідь: коли простіше передати ресурс об'єкта як посилання на об'єкти, які його потребують, а не дозволяти об'єктам звертатися до ресурсу глобально. Реальна проблема з Singleton полягає в тому, що вони дають вам таке гарне виправдання, щоб не думати про відповідну видимість об'єкта. Пошук правильного балансу експозиції та захисту об'єкта має вирішальне значення для підтримки гнучкості коду