У меня есть следующий код:
<?php
$start = 1;
$timestart = microtime(1);
for ($i = 0; $i < 1000000; $i++) {
$result1 = $start * 4;
}
echo "\n";
echo microtime(1) - $timestart;
echo "\n";
$timestart = microtime(1);
for ($i = 0; $i < 1000000; $i++) {
$result2 = $start << 2;
}
echo "\n";
echo microtime(1) - $timestart;
echo "\n";
Это выводит:
0.14027094841003
0.12061500549316
Я нашел в Интернете вопрос об интервью Google (который я хотел подать на разработчика, ноЯ понимаю, что не могу), и на один из вопросов был задан вопрос, как быстрее всего умножить число.Моей первой мыслью было использовать знак *
, поэтому я протестировал его.
Мой вопрос: почему сдвиг бит быстрее умножения?