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
Orzeszekk
post
Post #2





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

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


prywatna stałą mozna sobie stworzyc w klasie za pomocą konstrukcji private static $stała = "costam". jednak jest to swojego rodzaju hack. Co prawda nie jest to stała, ale daje to mozliwosc przechowywania stałej klasowej.

do plusow skladni php mozna zaliczyc late static binding - static::. bardzo fajna rzecz ktorej raczej nie ma w innych językach.
jednak jak sie pomysli ilu fajnych rzeczy PHP nie ma a inne jez. maja, to włos sie jezy na glowie.

wszystko juz chlopaki napisaliscie, i to jest wszystko prawda niestety. Ja od siebie bym dorzucil brak standardowego class Loadera.
metoda __autoload powoduje ze autoloader w kazdym fw/projekcie dziala inaczej.
A ja mam np swoj wlasny autoloader ktory dziala na moim autorskim pomysle i ma strukture katalogow nie korzystajac z namespace ale nie ma tez dlugich nazw jak zend i co sie okazuje? Biblioteka PHPUnit nie jest w stanie odnalezc zaleznosci miedzy klasami i klasy nie chcą się ładować, i tego co juz napisalem nie moge testowac jednostkowo. Musze robic sztuczki typu wydzielenie kodu logicznego do innej klasy poza projektem, tam stestowac , i opakowac w obiekt juz nalezacy do projektu.

Wraz z wprowadzeniem namespacow (ktore sa troche nieudane - brak mozliwosci zaimportowania calej namespace - porazka. Bez aliasowania trzeba uzywac nazw typu orzech\myproject\mymodule\myclass() - jeszcze wieksza porazka.) mogli by wprowadzic standardowy class loader tak jak jest w javie i juz.

Jest jeszcze jeden zarzut mój do PHP : brak wielowątkowości, i wsparcia dla lockow/sekcji krytycznych
W sytuacji gdy kazdy proces PHP dziala w oddzielnym wątku, i nie ma mozliwosci zablokowac jednemu mozliwosci grzebania w pliku gdy zapisuje do niego drugi, język wiąże ci ręce. Musisz wszystko ładowac do bazy danych.
To samo sie tyczy memcache - brak locków w PHP powoduje ze zle napisana aplikacja korzystajaca z memcache po prostu sie zawiesi (w momencie gdy wpis sie przedawnia, wchodzi na raz x uzytkownikow na strone, i z powodu braku locków wszyscy na raz zaczynaja aktualizowac ten memcachowy wpis, leci x zapytan do bazy danych... itd itp). Ostatnio chcialem skorzystac z memcache - jak zobaczylem jakie problemy to powoduje to dalem sobie z nim spokój.
Niby są mechanizmy locków bazujące na tworzeniu plików ~lock, ale jaki to ma sens przy cachowaniu danych w memcache? (IMG:style_emoticons/default/smile.gif)
zreszta pliki lock nie sa niezawodne bo jesli php przelaczy sie na drugi wątek w momencie tworzenia tego pliczku to tez nam cuda wyjdą.

Celowo nie pisalem o flock poniewaz dziala w pelni tylko pod linuchem, a poza tym jest problem bo raz zalozonej blokady nie mozna zdjac po uplywie np 30 sekund wiec jesli zawiesi sie skrypt zapisujacy do pliku ktory sobie zablokowal to nigdy nie zostanie odblokowany.

IDE ktory jest naprawde dopracowany i w zasadzie jak dla mnie jedyny na rynku to phpStorm, to program wart kazdych pieniedzy.
Ma wszystko co potrzebne i co najwazniejsze - dziala. PHPUnit dziala. IntelliSense - dziala pieknie, lepiej niz w ecl. i netbeans.
Refaktoryzacje typu wydziel metode/stałą/zmienną - +50% do predkosci kodowania. Do tej pory myslalem ze w jezyku dynamicznym sie nie da tego zrobic, ale jednak sie da. Predkosc IntelliSense (podpowiadania metod) - dziala jak eclipse pod javą czyli bez zastanowienia.
eclipse php/netbeans potrzebuje sekunde - piec przy duzym projekcie. wiec akurat edytor php od jakigos czasu nie ustepuje innym językom. Jak ktos chce wydajnie kodowac i szanuje swoj czas, taki edytor to raczej must have, notatnik/PDT to zamiana koparki na łopatę.
Nawet brak głupiego rename refactoring w edytorze, powoduje z czasem zaciemnianie sensu kodu - komu sie chce recznie zmieniac iles tam nazw zmiennych w kodzie? a to normalne ze zmienne z czasem zmieniaja swoje znaczenie..

no i idiotyczne operatory. operator obiektowosci -> . Operator namespace \ . Operator konkatenacji . (kropka). To jedyny jezyk ktory znam, ktory nie stosuje kropki jako obiektowosci\namespace oraz plusa jako konkatenacji. Brak overloadingu - przeciazania metod.
To spore utrudnienie przynajmniej dla mnie bo ja czesto uzywam tego w innych językach.

PHP jest wolny - poprawnie napisana aplikacja moze dzialac wolniej (i to sporo) od napisanej byle jak. Te wszystkie iteratory, gettery, settery powoduja swoj narzut. Takie symfony2 np 300 ms generuje pusta strone w trybie produkcyjnym.
Odswiezenie pustej strony w asp.net to czas jakichs 10 ms? moze mniej nawet. W javie zapewne jest podobnie. Skompilowany jezyk dziala znacznie szybciej i lepiej sobie radzi z kodem napisanym z wzorcami projektowymi ktore zazwyczaj daja pewien niewielki narzut wydajnosciowy, ktory jednak sie kumuluje.

styl pisania symfony2 na pewno nie jest archaiczny (IMG:style_emoticons/default/smile.gif) powiedzialbym nawet ze jak na php jest nowoczesny (IMG:style_emoticons/default/biggrin.gif)

Marcio: aplikacja webowa w javie uruchamia sie raz i dziala sobie w tle na serverze, jako servlet (cos jak usługa, tak mi sie wydaje). Po prostu sobie dziala. Korzysc juz tutaj masz bardzo duża: konfiguracja zostaje wczytana tylko raz.

w momencie requestu na strone ta dzialajaca aplikacja odpowiada na niego. Mozesz przechowywac sesje uzytkownika w pamieci aplikacji, kod jest skompilowany do kodu bajtowego wiec dziala szybko... Niektore czesto wykorzystywane obiekty mozesz trzymac w puli (np pule polaczen z baza danych) i nie tworzyc ich od nowa za kazdym razem.

natomiast PHP za kazdym razem includuje wszystkie pliki, odczytuje konfiguracje (define są dosc wolne jak na zwykla deklaracje stałej, ok 200 stałych to u mnie 10 ms), oblicza tysiac durnych rzeczy i dopiero wykonuje te kilka linijek kodu ktore mamy w naszym kontrolerze. Prawda ze to marnotrastwo? Choc trzeba przyznac ze php ma o polowe mniejsze zuzycie pamieci niz java.

w najnowszej wersji net. frameworka wprowadzono typ zmiennej [b]dynamic[/d], jest to typ zmiennej oparty na takim typowaniu jak ma php. Jednoczesnie sam net.framework jest statyczny. Daje to nam mozliwosc uzywania typow tam gdzie jest potrzebna bezblednosc oraz uzywania zmiennych bez typów tam gdzie nam wygodniej. I tak to rowniez powinno dzialac w php. co prawda są typy proste w php5.4 jednak nim on sie upowszechni to wieki miną.

Ten post edytował Orzeszekk 23.02.2012, 01:28:50
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
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 7.10.2025 - 13:43