PHP, (i aslında ne düşündüğünü aksine) Orada basit fonksiyonları vs statik yöntemlerini çağırarak bir yükü.
On a very simple bench, this overhead is over 30% of the calling time (the method just returns the parameter):
// bench static method
$starttime = microtime(true);
for ($i = 0; $i< 10*1000*1000; $i++)
SomeClass::doTest($i);
echo "Static Time: " , (microtime(true)-$starttime) , " ms\n";
// bench object method
$starttime = microtime(true);
for ($i = 0; $i< 10*1000*1000; $i++)
$someObj->doTest($i);
echo "Object Time: " , (microtime(true)-$starttime) , " ms\n";
// bench function
$starttime = microtime(true);
for ($i = 0; $i< 10*1000*1000; $i++)
something_doTest($i);
echo "Function Time: " , (microtime(true)-$starttime) , " ms\n";
çıkışlar:
Static Time: 0.640204906464 ms
Object Time: 0.48961687088 ms
Function Time: 0.438289880753 ms
Ben aslında bir şey, 1 milyon kez arıyorum sürece gerçek zaman hala önemsiz olduğunu biliyorum, ama aslında onun orada olduğunu.
Herkes denemek ve sahne arkasında neler olduğunu açıklamak ister misin?
update:
- added object method bench