• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Przykrycie konstruktora metodą

Object Storage Arubacloud
+3 głosów
257 wizyt
pytanie zadane 19 listopada 2015 w PHP przez event15 Szeryf (93,790 p.)
edycja 19 listopada 2015 przez efiku
<?php

class Person
{
    private $name;
    private $surname;
    
    private function __construct($name, $surname)
    {
        $this->name    = $name;
        $this->surname = $surname;
    }
    
    public static function born($name, $surname)
    {
        return new self(
            $name,
            $surname
        );
    }
    
    public function changeName($newName)
    {
        $this->name = $name;
    }
}

$newPerson = Person::born('event', '15');
$newPerson->changeName('efik');

Oto kodzik. 

Mówię o zaletach. Klasy Person nie wywoła się w żaden sposób jak tylko poprzez znaną metodę born. Nikt nigdzie w kodzie nie stworzy tego poprzez new Person(). 

Chciałbym poznać opinię waszą na temat tego rozwiązania. 

Temat jest też poruszony na PHPersach

2 odpowiedzi

+1 głos
odpowiedź 19 listopada 2015 przez efiku Szeryf (75,160 p.)
Moje zdanie:
Jako iż nie potrafię tego lepiej wytłumaczyć odwołam się do "Rzeczywistości"
Klasa Person nie powinna być odpowiedzialna za "rodzenie nowej osoby".  ( Osoba sama się rodzi?? :D ) Nie powinna wgl posiadać takiej metody. Tą funkcją powinna zajmować się "Matka" tzn fabryka(factory method) która tworzy Ci odpowiednią osobę. :)

PS: Można dodać jeszcze final
komentarz 19 listopada 2015 przez event15 Szeryf (93,790 p.)
No tak, ale pomińmy nomenklaturę osoby.

W momencie, gdy mam tylko jeden rodzaj obiektu który tworzę używanie fabryki będzie generacją niepotrzebnego kodu.

Racja - stworzy to nam możliwość W PRZYSZŁOŚCI dodania nowych typów podobnych do tego obiektu. Ale w tej chwili wydaje się to zbędne.

jeżeli już by zamieniać to factory method.
komentarz 19 listopada 2015 przez efiku Szeryf (75,160 p.)
tej chwili może tak, ale kto wie ...

Moim zdaniem powinieneś zerknąć sobie jak projektował Norbert repozytorium MyDrinks na GH.

Czekamy na opinię innych^^
komentarz 19 listopada 2015 przez event15 Szeryf (93,790 p.)
Z final jest tak że PHPSpec nie łapie go ze względu na mechanizm refleksji :D
komentarz 19 listopada 2015 przez Ehlert Ekspert (212,670 p.)

W ramach zaproszenia od efika cheeky jaki jest cel tego żeby osoba rodziła drugą siebie? xD

komentarz 19 listopada 2015 przez event15 Szeryf (93,790 p.)
Hmm jest to agregate root w domenie. Powinien być jedyną "wtyczką" dostępu do wszystkich innych encji. W rzeczywistości polega to na tym, że poprzez tą klasę istnieje dostęp do zachowań innych klas, które są w kontekście agregatu.

Ona nie rodzi drugiej siebie. Ona hermetyzuje ściśle informacje o swojej implementacji poprzez stworzenie prywatnego konstruktora (którego nie da się nigdzie indziej wywołać) i przykrycie go specjalną metodą wytwórczą.
komentarz 19 listopada 2015 przez Comandeer Guru (601,590 p.)
Skoro już factory, to nie można zapomnieć zakodzić service, który nam je zwróci. Oczywiście wszystko ma swój własny interfejs, prawda?
komentarz 19 listopada 2015 przez event15 Szeryf (93,790 p.)
Zależy, co rozumiesz przez "wszystko" @Comandeer
komentarz 19 listopada 2015 przez event15 Szeryf (93,790 p.)
To się nazywa "Named Constructors" i rozwiązuje zagadnienie przeciążania konstruktorów w PHP, przy okazji ma zalety wyżej wymienione.

W niektórych przypadkach jest to ok, ale w chwiil, gdy nie ma się zupełnej pewności odnośnie ostatecznego wyglądu encji to lepiej pomyśleć o prostej factory method.

 

http://verraes.net/2014/06/named-constructors-in-php/

Problem raczej uznaję za rozwiązany.
komentarz 19 listopada 2015 przez efiku Szeryf (75,160 p.)
To zamykaj ;)
+1 głos
odpowiedź 19 listopada 2015 przez event15 Szeryf (93,790 p.)
Dostałem feedback na ChatRepajr.

Wady tego kodu mogą być takie: Narusza to w pewien sposób zasady SOLID, a dokładnie zasadę pojedyńczej odpowiedzialności no i zasadę open/close, czyli otwarte na rozszerzenia i zamknięte na zmiany.

O ile open/close rozumiem o tyle zastanawiam się nad SRP i nie do końca widzę w jaki sposób?

Podobne pytania

0 głosów
1 odpowiedź 117 wizyt
pytanie zadane 10 listopada 2015 w C i C++ przez patryk16 Obywatel (1,080 p.)
+1 głos
1 odpowiedź 184 wizyt
pytanie zadane 23 kwietnia 2019 w C i C++ przez Milo Obywatel (1,180 p.)
0 głosów
1 odpowiedź 537 wizyt
pytanie zadane 3 lipca 2015 w C i C++ przez Wiciorny Ekspert (270,230 p.)

92,584 zapytań

141,433 odpowiedzi

319,667 komentarzy

61,966 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...