Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> PHP vs reszta platform
Crozin
post
Post #1





Grupa: Zarejestrowani
Postów: 6 476
Pomógł: 1306
Dołączył: 6.08.2006
Skąd: Kraków

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


Na początek prośba do moderatorów by rozdzielić wątek na dwa.

Cytat
Chodzi ci o JEE czy nie trafilem, jesli mozesz opisz na co sie przerzuciles z jakich powodow jakie ma wady i zalety w poprowaniu do php twoje nowe narzedzie
Osobiście jestem w trakcie "przesiadki" na JEE i w żadnym wypadku nie można moich wypowiedzi traktować tutaj jako wypowiedzi kogoś kto ma z tą platformą spore obycie.
Prosiłeś o wypisanie wad i zalet tej platformy względem PHP tak więc i takie zestawienie znajdziesz poniżej, miej jednak na uwadze, że jak już wspomniałem JEE (a nawet i wiele elementów JSE) nie jest mi tak dobrze znaną technologią jak PHP, które znam od dobrych kilku lat. Na pewno z wielu wad/błędnych rozwiązań nie zdaję sobie nawet sprawy (brak wystarczającego doświadczenia), a jest ich na pewno cała masa - jak w każdym języku/platformie, szczególnie takiej która swoje początki miała w połowie lat 90 i dbała o wsteczną kompatybilność (to akurat zaleta) kosztem pewnych decyzji/rozwiązań (np. typy generyczne będące na dobrą sprawę jedynie lukrem składniowym).

Subiektywna lista:
Język:
  1. Java jest statycznie i silnie typowanym językiem co znacznie ułatwia pracę poprzez: znaczne poprawienie czytelności kodu; ułatwienie dokumentacji kodu; uniemożliwia mieszanie typami (popatrz chociażby na genialny sposób informowania o nieznalezieniu podciągu przez strpos - zamiast zwrócić "-1" zwracają "false", które jest w większości przypadków traktowane jak "0") nie wspominając już o wszelkiego rodzaju narzędziach typu IDE, które po prostu mogą w ogóle działać.
  2. Idiotoodporność PHP, która najbardziej krzywdzi właśnie początkujących, a bardziej doświadczonym sprawia jedynie problemy. Użyłeś nieistniejącej zmiennej/właśćwiości obiektu/elementu tablicy? Żaden problem, uznamy, że podano wartość null/false/0. Podałeś za dużo argumentów dla funkcji? Żaden problem, uznamy że tych nadmiarowych w ogóle nie ma. Podzieliłeś przez zero? Wszechświat się zapada, a zmienna przyjmuje boolean'owski fałsz i jedziemy dalej. Takich zachowań jest znacznie więcej i w najmniejszym stopniu nie są one pomocne.
  3. Deweloperzy PHP nie myślą i nie testują nowych elementów języka:
    • Pojawiły się wyjątki, a nie istniały praktycznie żadne predefiniowane, żadnych reguł co do ich użycia, żadnych elementów składni informujących o tym, że dany wyjątek może się w ogóle pojawić itd.
    • Wprowadzili domknięcia, ale nie dali już możliwości zdefiniowania czy domknięcie przekazane w argumencie dla funkcji (np. jako callback) ma mieć jeden, dwa czy może cztery argumenty? O ich typach nie wspominając.
    • Wprowadzają kolejne klasy do SPL-a (bardzo dobrze), ale wymyślili sobie, że jedna z nich - bodajże MessageFormatter - będzie mogło zwrócić NULL-a w wyrażeniu new MessageFormatter(..); (tak dla jasności jest to sprzeczne z "specyfikacją" języka.
    • Wprowadzili przestrzenie nazw, ale nie narzucili żadnego sposobu ich nazywania (zrobił to dopiero PSR-0, który nie jest jednak zawsze przestrzegany)
  4. Brak porządnego wsparcia dla Unikodu w PHP, ogromny burdel w bibliotece standardowej, [u]brak nowej, równoległej do istniejącej biblioteki standardowej[/i]
  5. Spore braki w elementach/strukturach języka: w PHP nie stworzysz sobie nie-publicznej/lokalnej klasy gdy potrzebujesz jej jedynie w obrębie innej klasy/przestrzeni nazw przez co cały projekt musi być zawalony jakimiś nieistotnymi klasami; nie stworzysz sobie prywatnej stałej w klasie; nie stworzysz typu wyliczeniowego; nie masz dostępu do adnotacji, anonimowych instancji itp.


Platforma:
  1. JEE jak sama nazwa wskazuje jest zdecydowanie bardziej "enterprise'owa". To dostęp do całej masy świetnych narzędzi, trzymanie się dobrych, utartych, a przede wszystkim sprawdzonych standardów co do których ma się pewność, że w ciągu najbliższych lat nawet jeżeli zostaną zamienione innymi nadal będą dobrze wspierane. Za JEE stoi cała masa korporacji co bardzo dobrze wpływa na jej stabilność. W tym zestawieniu PHP wygląda jak stojący na glinianych nogach, [brak mi weny ;] - kaleka?]. I bynajmniej nie jest to jak pojedynek Dawida i Goliata, tu ten ostatni jednak wygrywa.
  2. W PHP na dobrą sprawę na start nie dostajesz kompletnie nic. Żadnych mechanizmów mogących realnie wspierać cokolwiek. Jak już napisałem na całe szczęście kilka lat temu pojawienie się FW dla PHP uratowało je przed kompletnym porzuceniem. A JEE? JSP/JSF, EJB, CDI, JPA, JTA, JMS i jeszcze wiele, wiele innych 3-4 literowych akronimów. (IMG:style_emoticons/default/wink.gif)
  3. Oczywiście w/w to jedynie specyfikacje i zestawy interfejsów... bo w Javie masz możliwość realnego wyboru implementacji. Nie jesteś ograniczony do jednego producenta.
  4. Serwer aplikacji nie działa na zasadzie od żądania do żądania - to znacznie ułatwia pokonywanie ograniczeń protokołu HTTP oraz platformy klient-serwer. Masz rzeczywistą możliwość robienie dowolnych rzeczy na serwerze (bo nie ogranicza Cię ani środowisko uruchomieniowe dla języka, ani sam język bo Java jest po prostu szybka).


Tych punktów mogłoby tutaj być więcej. Ale PHP nie jest wcale jakimś niewyobrażalnym badziewiem. Jak każdy język ma spore możliwości, a w dobrych rękach można w nim stworzyć na prawdę świetne projekty.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
wookieb
post
Post #2





Grupa: Moderatorzy
Postów: 8 989
Pomógł: 1550
Dołączył: 8.08.2008
Skąd: Słupsk/Gdańsk




A po co Ci "locki" w PHP gdy chcesz skorzystać z memcache?
Go to the top of the page
+Quote Post
Orzeszekk
post
Post #3





Grupa: Zarejestrowani
Postów: 260
Pomógł: 14
Dołączył: 8.09.2011

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


Cytat(wookieb @ 24.02.2012, 11:18:03 ) *
A po co Ci "locki" w PHP gdy chcesz skorzystać z memcache?


masz jakis wpis w memcache. Ma on waznosc na 10 minut.
nastepnie x uzytkownikow (dajmy na to 100) akurat wchodzi w tym samym momencie na twoja strone, i potrzebuje tego wpisu w memcache.
Poniewaz sie przedawnil, probuja go utworzyc od nowa. poniewaz kazdy request dziala w oddzielnym wątku, i robia to mniej wiecej w tym samym momencie, nie wiedzą o sobie nawzajem, ze rownolegle requesty rowniez probuja utworzyc ten wpis na nowo.
leci 1000 zapytan do bazy danych, a nastepnie 1000 requestów zapisuje te dane w danej komórce pamieci.

Jezeli zapytanie do bazy danych trwa 500ms, to przez 500ms pomimo ze zapytanie juz jest wykonywane, kolejne requesty ktore wchodza na strone i żądają tej komorki pamieci memcache, robią swoje requesty od nowa, bo mysla ze komorka pamieci jest pusta - pierwszy request ktory wykonal zapytanie majace na celu odswiezyc cache, jeszcze nie zakonczyl swojego dzialania. I tak w kolko beda sie odpalac kolejne zapytania dopoki pierwszy request nie zakonczy zapytania i nie zapisze go w memcache.
Zazwyczaj cachuje sie duze partie danych wiec calkiem prawdopodobne ze to zapytanie bedzie trwalo dosc długo.

Z tego co widzialem i co jest w miare logiczne, aby uniknac tej sytuacji proponują aby swoje zapytania do memcache przekonstruowac tak ze każdy request zanim zacznie to zapytanie do bazy danych czy cokolwiek innego co ma zdobyc dane dla odswiezenia memcache, sprawdza czy zostala ustawiona flaga ze juz ktos to odswieza - zazwyczaj jest to np dodatkowa zmienna w memcache o jakiejs tam nazwie. To nawet dzialajaca solucja ale i tak nie do konca rozwiazuje problem, jesli ten pierwszy skrypt ktory zalozyl lock sie zawiesi, blokada nie zostanie zdjęta. Po za tym wątki moga zostac przelaczone w dowolnym momencie - np pierwszy proces ustawia flage lock, nastepnie system zatrzymuje ten watek i uruchamia drugi - drugi tez chce odswiezyc cache ale widzi ze flaga jest ustawiona więc czeka sleepem lub pętlą, zajmuje procesor, nastepnie przeskakuje do trzeciego.. tysiecznego i na koncu wraca do pierwszego ktory dopiero wtedy moze zaaktualizowac cache i dokonczyc prace i odblokowac reszte wątkow. gdyby byla sekcja krytyczna to nie byloby takiego problemu bo caly kod wykonalby sie za jednym razem bez przeskakiwania do innego wątku.

po za tym jest to smierdzące obejscie niedorobki w jezyku ktore powinno byc rozwiazane przez developerow php, ewentualnie memcache, a nie przez programistow korzystajacych z tych modułów. skoro php nie ma mechanizmow programowania wspolbieznego, to powinien byc zrobiony tak by programisci nie musieli sie wspolbieznoscia przejmowac.

Ten post edytował Orzeszekk 24.02.2012, 13:51:00
Go to the top of the page
+Quote Post

Posty w temacie
- Crozin   PHP vs reszta platform   22.02.2012, 13:51:10
- - marcio   CytatNa początek prośba do moderatorów by rozdziel...   22.02.2012, 15:16:04
- - Orzeszekk   prywatna stałą mozna sobie stworzyc w klasie za po...   23.02.2012, 01:11:21
- - wookieb   Cytat(Orzeszekk @ 23.02.2012, 01:11:2...   23.02.2012, 07:59:02
- - marcio   Cytatwszystko juz chlopaki napisaliscie, i to jest...   23.02.2012, 09:46:00
- - wookieb   Cytat(marcio @ 23.02.2012, 09:46:00 )...   23.02.2012, 09:49:59
- - marcio   CytatNie wspomniałeś bo nie rozróżniasz bibliotek ...   23.02.2012, 10:10:01
- - wookieb   Cytat(marcio @ 23.02.2012, 10:10:01 )...   23.02.2012, 10:17:03
- - marcio   Cytatżadna z bibliotek phpowy nie jest napisana fu...   23.02.2012, 10:45:58
- - by_ikar   CytatNie wspomniałeś bo nie rozróżniasz bibliotek ...   23.02.2012, 10:47:44
- - wookieb   Pisałem i pisze w ServerSide JavaScript - Jest ok,...   23.02.2012, 10:50:28
- - marcio   @by_ikar chodzi ci o HipHop?Tez mi sie cos o uczy ...   23.02.2012, 11:36:00
- - wookieb   Cytat(marcio @ 23.02.2012, 11:36:00 )...   23.02.2012, 11:45:51
- - Crozin   @wookieb: Tak, w Javie jest ClassLoader i jest jed...   23.02.2012, 11:50:50
- - by_ikar   Cytat@by_ikar chodzi ci o HipHop?Tez mi sie cos o ...   23.02.2012, 13:32:44
- - Cysiaczek   Marudzicie Jedyny problem PHP, który obecnie jest...   23.02.2012, 13:51:19
- - Theqos   Cytat(Crozin @ 22.02.2012, 13:51:10 )...   23.02.2012, 14:30:24
|- - rafio   Cytat(Theqos @ 23.02.2012, 14:30:24 )...   23.02.2012, 18:51:07
- - Niktoś   Ja bym postawił na C#,JEE, F#(niejako odmiana JEE)...   23.02.2012, 14:53:47
- - wookieb   Cytat(Theqos @ 23.02.2012, 14:30:24 )...   23.02.2012, 14:54:21
- - Theqos   Co ma load balancer do tego, że aplikacja trzyma u...   23.02.2012, 15:03:39
- - wookieb   No jeżeli zmuszasz appke do tego aby przechowywał ...   23.02.2012, 15:08:19
- - Theqos   Odnosiłem sie do serwera aplikacji, jaki to jest z...   23.02.2012, 15:20:44
- - Crozin   CytatI znacznie utrudnia skalowalność. Jak masz ni...   23.02.2012, 19:15:18
- - Orzeszekk   dorobilem sobie bootstrap do testow jednostkowych,...   23.02.2012, 21:36:53
- - wookieb   Cytat(Orzeszekk @ 23.02.2012, 21:36:5...   23.02.2012, 21:46:18
|- - Orzeszekk   Cytat(wookieb @ 23.02.2012, 21:46:18 ...   24.02.2012, 10:07:10
- - marcio   Sry ze zadam glupie pytanie ale jak mozna stworzyc...   24.02.2012, 01:17:06
- - wookieb   Tak samo jak łączysz się z bazą danych. Za pomocą ...   24.02.2012, 08:47:12
- - wookieb   A po co Ci "locki" w PHP gdy chcesz skor...   24.02.2012, 11:18:03
|- - Orzeszekk   Cytat(wookieb @ 24.02.2012, 11:18:03 ...   24.02.2012, 13:47:36
- - Crozin   @Orzeszekk: Ten problem można rozwiązać w bardzo p...   24.02.2012, 14:33:41
- - by_ikar   Akurat w przypadku danych do których dostęp musi b...   24.02.2012, 14:36:18
- - marcio   CytatPS. Wątek (tak jak się spodziewałem) w nic ko...   24.02.2012, 15:07:27
- - wookieb   Cytat(Crozin @ 24.02.2012, 14:33:41 )...   24.02.2012, 15:31:32
- - Crozin   @wookieb: W sumie to dokładnie tego co się tutaj p...   24.02.2012, 15:50:56
- - wookieb   Cytat(Crozin @ 24.02.2012, 15:50:56 )...   24.02.2012, 16:04:44
- - Niktoś   CytatTo dlaczego mówisz, że wątek nie przerodził s...   24.02.2012, 16:36:36
- - wookieb   Jeżeli ktoś chce się nauczyć czegoś sensownego abl...   24.02.2012, 16:44:36
- - nasty   Autoloader moze byc wydajnie zaimplementowany tylk...   25.02.2012, 02:47:03


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: 9.10.2025 - 14:51