Ад Синглтона

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


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

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

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

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

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

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

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

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

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

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

-----------

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

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

Архив записей в блогах:
И снова нет повода не выпить бокал преднизолона закусив бутербродом с мельдонием. Хакерская группа Fancy Bear опубликовала очередной список спортсменов употреблявших допинг с разрешения WADA. Хакеры опубликовали еще одну часть базы данных WADA Хакерская группировка Fancy Bears в ...
Где-то в далёких и теплых краях жили были стая лебедей. Все у них было в шоколаде, но им хотелось мир посмотреть. Вот и в один прекрасный день они полетели не прощаясь. И это вовсе не сказка. Позавчера машиной поехали по Саранпаулю (ХМАО) посмотреть масштабы наводнения.На объездном ...
По наблюдению, идущему от римского историка Корнелия Тацита, «у победы тысяча отцов, а поражение обычно сирота». Актуально именно сейчас. Нет, #Украина пока не потерпела поражения, и «контр» наступление на востоке ещё продолжается ценой каждодневного размена сотен жизней на метры ...
Как нас поили в школе этим вот компотом из сухофруктов. И как вы на большой перемене запивали им пирожок с повидлой! В общем не ностальгия, конечно, замучила, а просто я всю жизнь люблю этот компот, и кроме того этим летом насушен был мешок яблок ...
девочки и мальчики! вы чем растительность на теле удаляете? и удаляете ли? ...