Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Interfejs i klasa abstrakcyjna
daniel1302
post
Post #1





Grupa: Zarejestrowani
Postów: 602
Pomógł: 30
Dołączył: 1.08.2007
Skąd: Nowy Sącz

Ostrzeżenie: (0%)
-----


Witam, mam problem teoretyczny. Jest taka sytuacja
Mam klasę abstrakcyjną Człowiek, która realizuje jakieś opcje.
I różni ludzie dziedziczą po tej klasie np:

  1. class Daniel extends Czlowiek
  2. {
  3. ...
  4. }


i chcę aby każdy człowiek posiadał odpowiednie metody(które np ustalają co człowiek potrafi, jak myśli, dla każdego wykonanie tej metody ma być inna).

mogę zrealizować to za pomocą interfejsu np. Interface Genetyka
  1. interface Genetyka
  2. {
  3. public function wyglad();
  4. public function umiejetnosci();
  5. }

i wtedy będę miał:
  1. class Daniel extends Czlowiek implements Genetyka
  2. {
  3. ...
  4. }

ale coś mnie to kole w oczy. Ale mogę dodać metody do klasy abstrakcyjnej skoro i tak każdy człowiek po niej dziedziczy.
Co wy byście zrobili. Zastosowali interface czy dodali definicje metod do klasy.

Ten post edytował daniel1302 30.11.2011, 17:32:19
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
LSM
post
Post #2





Grupa: Zarejestrowani
Postów: 64
Pomógł: 6
Dołączył: 20.03.2011
Skąd: Świdnica

Ostrzeżenie: (0%)
-----


Cytat
Jak zajdzie potrzeba zmian to kolega sobie to zrefaktoryzuje i juz

Dokładnie tak się powinno trworzyć aplikację. Uelastycznianie na wyrost to poważny błąd. A co jeśli w aplikacji będzie 4 aktorów o różnych imieniach i przez kolejne 10 lat nic poza tym ? Myślenie o elastyczności w takim przypadku nie ma sensu. Macie wszyscy po trochu racji, ale jak zwykle na tym forum.. eh nie ważne.
Każdy z was mówi o nieco innych przypadkach i podejściach. Najlogiczniejsze jest dla mnie to co pisze Orzeszekk. Dziedziczenie jest użyteczne, przy komplikowaniu się kodu w którym jest ono używane - należy go refaktoryzować w celu stosownia np. Strategii, ale nigdy tych czynności nie należy robić zbyt wcześnie ponieważ elastyczność potrafi niepotrzebnie skomplikować projekt.

A poza tym nie ma wiedzy jedynie prawdziwej, biorąc pod uwagę fakt oszczędzania czasu i nie marnowania go na "kombinatorykę elastyczną" - należy pójść na początku po najmniejszej linii oporu Orzeszka, jeśli zajdzie potrzeba użyć rozwiązania Crozina lub zupełnie innego, bo można ten apsekt zaprogramować na dziesiątki sposobów. Będzie to zależeć od wymagań jakie postawi nam dalszy rozwój aplikacji. Jeśli Crozin na początku zaczniesz wszystko uelastyczniać na "wydaje mi się" - możesz się zakopać w swoich kombinacjach i gdy przyjdzie czas na wdrożenie czegoś nowego okarze się, że tak uelastyczniłeś system, że stał się nieczytelny i trudny w rozwoju. Niekoniecznie to co napisałeś musi być jedynie prawdziwe i poprawne. Znajde Ci 10 sposobów różnych na to jak sprawić aby to rozwiązanie Człowieka było elastyczne i przygotowane na ewentualnie - każdą zmiane - ale takie myślenie nie ma zupełnie sensu, jest alogiczne, bo który sposób wybierzesz ? A jeśli strategia którą wybierzesz okarze się nieużyteczna i błędna to będziesz musiał zmienić większą ilość kodu niż przed wprowadzeniem strategii. Z elastycznością czeka się do ostatniego momentu - nigdy nie robi się tego na samym początku projektowania. Tak podpowiada mi moje doświadczenie.

(IMG:style_emoticons/default/oneeyedsmiley02.png)
Go to the top of the page
+Quote Post

Posty w temacie
- daniel1302   Interfejs i klasa abstrakcyjna   30.11.2011, 16:40:20
- - Orzeszekk   Najczysciej będzie jak zrobisz najpierw interfejs ...   30.11.2011, 19:50:16
- - Crozin   To co tu kole w oczy to kompletny brak związku z O...   30.11.2011, 20:53:33
|- - Orzeszekk   Cytat(Crozin @ 30.11.2011, 20:53:33 )...   30.11.2011, 22:25:27
- - Crozin   CytatCzy Daniel nie jest czlowiekiem? Czy Kamil - ...   30.11.2011, 22:56:51
|- - Orzeszekk   Cytat(Crozin @ 30.11.2011, 22:56:51 )...   30.11.2011, 23:09:31
- - Dipter   @Orzeszekk Twoje uwagi w stosunku do Crozina mają...   30.11.2011, 23:20:09
- - ano   Orzeszekkk... przecież to teraz Ty strasznie miesz...   30.11.2011, 23:26:36
- - Orzeszekk   Jak tam sobie chcecie. Dla mnie nielogiczne jest z...   30.11.2011, 23:39:31
- - Dipter   Zacznijmy od tego, że to że Daniel to świr i ma ni...   30.11.2011, 23:49:43
|- - Orzeszekk   Cytat(Dipter @ 30.11.2011, 23:49:43 )...   30.11.2011, 23:53:07
- - ano   Dalej to co mówisz jest nielogiczne. Z tego by wyn...   30.11.2011, 23:51:03
- - Dipter   Dlaczego metodą? Może być równie dobrze obiektem k...   30.11.2011, 23:59:29
|- - Orzeszekk   Cytat(Dipter @ 30.11.2011, 23:59:29 )...   1.12.2011, 00:04:47
- - Dipter   Na Ciebie nigdzie nie wjeżdżam więc przestań zmyśl...   1.12.2011, 00:10:20
- - LSM   CytatJak zajdzie potrzeba zmian to kolega sobie to...   1.12.2011, 09:58:24
- - phpion   @Orzeszekk: [PHP] pobierz, plaintext class Human ...   1.12.2011, 10:14:49
- - Pilsener   CytatZ elastycznością czeka się do ostatniego mome...   1.12.2011, 14:28:18
- - LSM   @Pilsener Nie zrozumiałeś mnie. Zdarzyło Ci się ki...   2.12.2011, 10:05:29
- - bastard13   Zgadzam się z LSM, że myślenie 'na przyszłość...   2.12.2011, 11:33:03
- - daniel1302   Może opiszę projekt dokładniej. Tworzę algorytm gr...   2.12.2011, 17:47:04
- - Crozin   No to możesz to zrobić w taki sposób:[PHP] pobierz...   2.12.2011, 19:22:17
- - daniel1302   Dziękuje, temat jest dosyć wyczerpujący. Assembler...   2.12.2011, 21:46:18
- - LSM   Jeśli chcesz to przepisać na assemblera, to nie le...   4.12.2011, 14:17:51


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 12.10.2025 - 23:52