![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 55 Pomógł: 0 Dołączył: 17.09.2006 Ostrzeżenie: (0%) ![]() ![]() |
Wykonałem krótkie testy porównujące szybkości działania funkcji z parametrem przekazanym przez wartość, referencję i obiekt. Musze przyznać, że wyniki troche mnie zaskoczyły.
Środowisko: PHP 5.2.1RC2 Apache 2.2.4 Przykład 1
Średnie wyniki z 10 pomiarów: ObjFunc: 0,03630816936492920 ObjMet: 0,01625814437866210 Tab: 0,02549026012420650 TabRef: 0,01591291427612310 Opis wyników ObjFunc jest 2x wolniejsze niż wywołanie metody obiektu ObjMet Tab jest 1.6x wolniejsze od funkcji z parametrem referencyjnym!!! Wnioski 1. Okazuje się, że wbrew dokumentacji PHP, przekazanie parametu przez referencję jest dużo szybsze niż przekazanie wartości. Należy się domyślać, że dotyczy to raczej zmiennych o dość rozmiarach. 2. Wywołanie metody obiektu jest znacznie szybsze niż (trochę dziwna) funkcja. Drugi test jest jeszcze ciekawszy! Tym razem modyfikujemy zmienną przekazaną do funkcji/metody. Przykład 2
Średnie wyniki z 10 pomiarów: ObjFunc: 0,00535948276519776 ObjMet: 0,00558812618255616 Tab: 12,12336094379430000 TabRef: 0,00451698303222655 Opis wyników ObjFunc i ObjMet mają bardzo zbliżone wyniki. Zaskakuje natomiast funkcja Tab z wynikiem ponad 2000x gorszym od innych sposobów!!!! w tym od funkcji z parametrem referencyjnym. Wnioski 1. Porównując wyniki z Przykładu 1 i 2 widzimy, że PHP wykonując funkcję z parametrem wartościowym nie tworzy kopii tego paremetru za każdym razem. Taka kopia generowana jest tylko wtedy, gdy zmienna ulega zmianie wewnątrz funkcji! 2. Przekazywanie do funkcji dużych zmiennych przez wartość jest wolniejsze niż przekazanie ich przez referencję, nawet jeśli zmienna nie ulega modyfikacji wewnątrz funkcji! 3. Wywoływanie i działanie fukcji/metod na obiektach może być nieco wolniejsze od funkcji na tablicach, ale różnica nie jest duża. Ten post edytował gWd 18.04.2007, 12:19:17 -------------------- art of programming
|
|
|
![]()
Post
#2
|
|
Grupa: Przyjaciele php.pl Postów: 7 494 Pomógł: 302 Dołączył: 31.03.2004 Ostrzeżenie: (0%) ![]() ![]() |
Jaka wersja PHP?
|
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 55 Pomógł: 0 Dołączył: 17.09.2006 Ostrzeżenie: (0%) ![]() ![]() |
Teraz wykonamy wersję testu 1, ale tym razem z 10x mniejszą zmienną.
Przykład 3
Średnie wyniki z 10 pomiarów: ObjFunc: 0,04068577289581310 ObjMet: 0,03742690086364740 Tab: 0,01934800148010270 TabRef: 0,03726780414581290 Opis wyników Tab jest 2x szybsze od TabRef Wnioski W porównaniu do przykładu 1, widzimy dużo lepsze wyniki funkcji Tab. Dlatego łatwo można wyciągnąć wniosek, że funkcja z parametrem wartościowym jest jednak szybsza od fukcji z parametrem referencyjnym. Przekazanie tablicy przez referencję jest porównywalnie szybkie jak przekazanie obiektu lub wywołanie metody obiektu. I ostatni test Tym razem zmiejszyłem rozmiar zmiennej do 10 pól integer (z 10000 w pierwszym teście) i wykonałem funkcje modyfikujące przekazaną zmienną, tym razem równierz funckaj Tab, która nieznacznie zmieniłem, aby zwracała zmienną o nowej wartości. Przykład 4
Średnie wyniki z 10 pomiarów: ObjFunc: 0,01284565925598150 ObjMet: 0,01222741603851320 Tab: 0,03661031723022470 TabRef: 0,01396517753601080 Opis wyników Tab jest (tylko) 2.6x wolniejsza od TabRef. Wnioski 1. Jeżeli w wyniku działania funkcji zmienna ma ulec zmianie, to przekazanie do funkcji nawet stosunkowo małych zmiennych przez referencję jest korzystniejsze niż przekaznie ich przez wartość. 2. Dlatego może się opłacać zamienieie tablicy na obiekt, albo wogle korzystanie z samych obiektów. Ten post edytował gWd 18.04.2007, 13:18:16 -------------------- art of programming
|
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 1 470 Pomógł: 75 Dołączył: 21.09.2005 Skąd: że znowu Ostrzeżenie: (0%) ![]() ![]() |
wydaje mi się że w testach powinieneś uwzględnić czas tworzenia zmiennych/tablic/obiektów - bo co z tego że operacja jest szybsza skoro operacja plus utworzenie obiektu/tablicy jest już znacznie wolniejsza.
-------------------- |
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 55 Pomógł: 0 Dołączył: 17.09.2006 Ostrzeżenie: (0%) ![]() ![]() |
wydaje mi się że w testach powinieneś uwzględnić czas tworzenia zmiennych/tablic/obiektów - bo co z tego że operacja jest szybsza skoro operacja plus utworzenie obiektu/tablicy jest już znacznie wolniejsza. W testach chodziło o porównanie parametrów wartościowych i referencyjnych. Obiekty dodałem tylko dla porównania, czy ich stosowanie różni się od stosowania innych typów referencyjnych. Nie miałem zamiaru udowadniać wyższości programowania obiektowego czy strukturalnego. Ale zawsze możesz na podstawie załączonego kodu wykonać własne testy i przedstawić wyniki. Ten post edytował gWd 18.04.2007, 12:55:00 -------------------- art of programming
|
|
|
![]()
Post
#6
|
|
![]() Grupa: Zarejestrowani Postów: 1 470 Pomógł: 75 Dołączył: 21.09.2005 Skąd: że znowu Ostrzeżenie: (0%) ![]() ![]() |
W testach chodziło o porównanie parametrów wartościowych i referencyjnych. Obiekty dodałem tylko dla porównania, czy ich stosowanie różni się od stosowania innych typów referencyjnych. Nie miałem zamiaru udowadniać wyższości programowania obiektowego czy strukturalnego. Ale zawsze możesz na podstawie załączonego kodu wykonać własne testy i przedstawić wyniki. nie zrozum mnie źle - nie chcę udowadniać wyższości jednego nad drugim. Twierdze tylko że nieuwzględnienie w testach czasu potrzebnego na zbudowanie danej zmiennej (czy to tablicy czy obiektu) nie jest miarodajne. Ogólni test bardzo fajny - wyniki faktycznie nieco zasakujące. -------------------- |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 55 Pomógł: 0 Dołączył: 17.09.2006 Ostrzeżenie: (0%) ![]() ![]() |
Test nie związany z tematem, ale mam nadzieję zaspokajający ciekawość devnula...
Tworzymy 1000 tablic, każda po 10 pól i 1000 obiektów każdy po 10 pól:
Wyniki Tabele: 0.026139974594116 Obiekty: 0.031857967376709 Wnioski Tabele zgodnie z oczekiwaniami są szybsze od obiektów, ale nie jest to różnica powalająca, zaledwie 22%. -------------------- art of programming
|
|
|
![]() ![]() |
![]() |
Wersja Lo-Fi | Aktualny czas: 14.06.2025 - 17:15 |