Ад Синглтона

топ 100 блогов ru_php25.05.2010 Предлагаю обсудить плохие стороны паттерна Singleton.


Что хорошего дает синглтон?

1. Во-первых он заменяет нам глобальные переменные, и пользуясь правильным именем класса мы не войдем в конфликт с классами из сторонних библиотек.

2. Синглтон доступен из любого места программы в один шаг, -- не надо отслеживать как и какой параметр передался по цепочке вызовов и почему в нужном месте оказалось, что контекст вдруг не тот. Т.е. имеется простота использования.

3. В синглтон можно запихнуть IoC-контейнер и раздавать не только значения переменных, но и строить объекты нужных типов весьма гибким образом, снижая таким образом зависимости.

Что в синглтоне плохо?

1. Во-первых неудобно тестить. И правда если нам надо потестировать разные классы, которые используют разные настройки, то состояние синглтона от теста к тесту будет меняться.

Эта проблема решается довольно легко. Достаточно добавить в наш синглтон методы push и pop, чтобы можно было запомнить состояние и легко его восстановить.

2. Во-вторых. Если после использования синглтона объектом состояние синглтона меняется, то это вносить нестабильность в программу. Однако этот вопрос решается дициплиной. Обычные объекты ничего в синглтоне менять не должны.

3. В третьих. Параллельная работа. Если у нас в одном рабочем пространстве начинают работать два процесса. Я не писал демонов и вообще параллельных процессов. Но если бы вдруг один и тот же скрипт обрабатывал два запроса в параллель, то наш Синглтон нам бы ого-го как икнулся. Например сунули мы туда значение локали, а у запросов языки разные. Тут нужно от синглтона отказываться. Но до этого места надо дожить еще, -- если можно скажите используете ли вы параллельную работу в одном процессе и в какой ситуации.

Вот тут есть презентация про разные вкусы Синглтона на Джаве

-----------

Понятно, что от Синглтона можно отказаться, но это станет в некоторую копеечку, т.к. придется по классам контроллера и по классам модели таскать за собой контекст. Вопрос стоит ли оно того?

Оставить комментарий

Архив записей в блогах:
«Тонко чувствующий» Майдан министр внутренних дел Украины, судя по всему, использовал собственный опыт и слабые места митингующих. Вор Янукович на фоне новой укровласти — ягненок. Образец гуманизма и порядочности. Картинка кликабельна ПРАВООХРАНИТЕЛИ ХАРЬКОВЩИНЫ И ...
Я лучше поеду на конференцию, чем отдыхать, практически в любое место. И лучше схожу на лекцию, чем в кино. Год назад я потратила в Лондоне на книги в полтора раза больше чем на шмотки. Сегодня с меня смеялись, когда я сказала, что хочу работать всю ...
Бешеная тварь. Данное словосочетание в ходу практически у всех, кто хоть однажды сталкивался с актриской Яной Трояновой *. Тётя 100% забесовленная, разрушающая всё вокруг себя. Единственный официальный муж по фамилии Ширинкин дичайшим образом бухал, обсинячился вконец и ...
Я в шоке! Просто в шоке! У мое знакомой ребенок-подросток. Будучи человеком интеллигентным, она старалась не нарушать его внутреннее пространство. Письма не читала по СМС не лазила. Потом начала замечать, что он шлет смс-ки по полночи. Решила ...
По ходу, начиталась массу нелицеприятных рецензий на кино, да плюс Гая Ричи я не ...