Martio
11.10.2006, 09:57:58
Doczytałem się o wielu zaletach używania wzorca Singleton. Jednak nigdzie o jego wadach. Czy jest on tak doskonały, że nie posiada wad? Jeżeli jednak takowe posiada, to jakie?
Jak rozwiązanie jest bardziej optymalne i wydajne chcąc uruchomić tylko jedną jedyną instancję każdej klasy? Czy użycie wzroca Singleton czy Register (rejestr, do którego są rejestrowane wszystkie obiekty)? A może macie inne, lepsze rozwiązania na tworzenie po jednej instancji obiektu klasy?
Na początku w aplikacji posiadałem kilka singletonów ( praktycznie wszędzie ), ale z czasem doszedłem do wniosku, że singletony są do pupy i można sobie doskonale radzić bez nich.
Tak naprawdę pytanie jest czy naprawdę potrzebujesz zabezpieczyć daną klasę by powstał tylko jeden obiekt i ani jeden więcej? Czy nie lepiej po prostu przekazywać dany obiekt ( np. request, response , currentUser ... ) do poszczególnych części aplikacji, które z tego korzystają ( w phiend2 patrz context ). Ktoś sobie może stworzyć drugi obiekt request w środku akcji, ale czy to mu coś da? Po prostu to nic mu nie da i tyle ;-)
Aktualnie singleton wykorzystuje tylko w przypadku połączenia z bazą danych.
Przy okazji, jeśli w środku akcji stosujesz np. $oRequest = Request::getInstance() ... a po pewnym czasie stworzysz sobie inną klasę Request2 ... to teraz sobie wyobraź, że wszędzie, we wszystkich akcjach będziesz musiał zmieniać nazwę... porażka :/ Dlatego lepiej mieć jedno miejsce gdzie się tworzy obiekt na bazie jakieś klasy i w pozostałych miejscach się z niego korzysta.
Turgon
11.10.2006, 13:34:54
sf: Rozwiązanie proste. Coś ala fabryka połączona z rejestrem.
bim2
11.10.2006, 14:40:49
no własnie mozna tez zrobic (jesli ktos korzysta z autoload np. Rapide) że w autoload() dasz $oPlugin->registerPlugin($oKlasa); a pozniej odowlujesz sie gdzies do pluginu

Ja tak mam
Martio
11.10.2006, 17:28:16
Mam klasę od serwowania tekstów we właściwej wersji językowej. W jej konstruktorze odbywa się parsowanie XML, a więc zależy mi na tym, aby była tylko jedna instancja tej klasy. Macie jakieś pomysły na to?
Turgon
11.10.2006, 19:37:58
Jak mówiłem wcześniej autoload plus rejestr. Więc jak skończę mojego dev-bloga napiszę notę na ten temat.
Prph
11.10.2006, 19:52:50
Cytat(Martio @ 11.10.2006, 16:28:16 )

Mam klasę od serwowania tekstów we właściwej wersji językowej. W jej konstruktorze odbywa się parsowanie XML, a więc zależy mi na tym, aby była tylko jedna instancja tej klasy. Macie jakieś pomysły na to?
Ja uzylbym Singleton, chociaz Twoj opis nie jest wyczerpujacy

W swoim frameworku uzywalm tylko 2 singletonow - Controller_Front i Language. Powod: nie chce przekazywac wszedzie frontkontrolera. Niech jest singletonem i bedzie dostepny globalnie. Co do Language - nie umialem inaczej tego rozwiazac. Singleton wydaje sie dobrym rozwiazaniem.
Adrian.
bim2
11.10.2006, 21:17:06
Wzoruje się na rapidzie ale language walnołem w pluginy

a w controllerze mam getPlugin('jakis_plugin') który odwołuje się do obiektu language i metody getPlugin()
UDAT
13.10.2006, 13:50:29
Cytat(Martio @ 11.10.2006, 10:57:58 )

A może macie inne, lepsze rozwiązania na tworzenie po jednej instancji obiektu klasy?
Wykorzystanie aspektów, np.:
phpAspect - dział Examples albo kontener IOC
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę
kliknij tutaj.