Ад Синглтона

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


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

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

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

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

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

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

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

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

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

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

-----------

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

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

Архив записей в блогах:
Друзья, давайте все вместе поможем хорошей девушке. Нет, денег никуда высылать не надо.Все гораздо проще и сложнее одновременно. Эта девушка замужем. Муж дико ревнив. Этой девушке один знакомый из Сети выслал в подарок веб-камеру. ...
Потолстительное.  А знание такое: 1. совсем необязательно слоёное тесто размораживать перед выпеканием. 2. Можно обойтись сковородкой — уж сковородка-то в любом доме ...
Моя интернет популярность (ахах!:) ну еще есть куда стремиться), последнее время все чаще приносит новые и новые сюрпризы, события, которые  заставляют задуматься, неожиданные встречи с людьми из прошлого и с новыми знакомыми, приятности и ...
За первые три месяца года я потерял три месяца, но это не повод не продолжать попытки сбросить жир к лету. По крайней мере предыдущие два года это удавалось, очень далеко до кубков, но более менее до приличного вида, когда пивная цистерна спереди уменьшилась до размера аккуратной ...
Буду кратка . Поздравляю ВСЕХ мужчин с праздником . И хочу "причислить" его не только к тем , кто служил , а именно ко всем мальчикам - дядям - старикам ! Знаю, что некоторые не проходили армейской закалки по определенным причинам , но это вовсе не значит , что они на защитники и что мы ...