Thanks for ur interest. Seairth Jacobs <[EMAIL PROTECTED]> wrote in message [EMAIL PROTECTED]">news:[EMAIL PROTECTED]... > I have a couple thoughts... > > 1) In some other languages, passing an array by value only passes the first > element value, not the whole array. This may be happening here, which would > explay the fast execution times. I don't know this for sure, but it could > easily be tested by seeing what's in $a inside the function f(). > > 2) Try returning the array by reference... > > function &f(&$a){return $a;} > > for ($i=0; $i < 100; $i++){$a = & f($big);} > > --- > Seairth Jacobs > [EMAIL PROTECTED] > > > "Markas" <[EMAIL PROTECTED]> wrote in message > [EMAIL PROTECTED]">news:[EMAIL PROTECTED]... > > I tried some trivial expirements: > > > > /* here I define an array $big, which I guess would "eat" ~100kb of memory > > */ > > for($i=0; $i<10000; $i++) > > { > > $big[$i] = "1234567890"; > > } > > > > /* this func only returns the value it gets as a param...*/ > > function f($a){return $a;} > > > > $start = microtime(); > > > > /* here all the job is done */ > > for ($i=0; $i < 100; $i++){$a = f($big);} /* <--- every iteration I just > > pass $big array to this func and it simply returns it*/ > > > > $end = microtime(); > > > > /* here I find out the time the job above takes to run, similar to the > code > > from the help:*/ > > function > > microtime($time){ > > list($usec, $sec) = explode(" ",$time); > > return ((float)$usec + (float)$sec); > > } > > > > $time_start = getmicrotime($start); > > $time_end = getmicrotime($end); > > $time = $time_end - $time_start; > > > > echo "Did nothing in $time seconds"; > > > > So the script above takes on my server ~0.00115 sec, so as far as I > understand, it takes php to copy that $big array which is rather large, at > least 100 times... So I decided to change the function f($a): > > function f($a){return $a;} changed to function f(&$a){return $a;}, > > as you can see, I only wanted to pass that $a param by reference, without > copying it, so I thought I win in performance and the 100 iterations will > work faster, as no copying of such a large array $big (which is this time > going to be passed by refernce) will be involved,... BUT this case the job > took ~3.75093 seconds, which is 3262 times SLOWER !!! I also found out, > that while using refernces, the time of job's run strictly depends on the > $big array dimension, and while NOT using references, the time doesn't > depend on that, but I thought just on the contrary. I thought, that while > using references, we dont copy the data and therefore do not depend on that > data amount, but the example above shows just the opposite results... > > > > What's going on, if anybody gets interested, please explain? > > > > > > > > > > > > > > > >
-- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php