Подтвердить что ты не робот

PHP-рекурсивная папка readdir vs find performance

я столкнулся с несколькими статьями о производительности и readdir здесь находится php script:

function getDirectory( $path = '.', $level = 0 ) { 
    $ignore = array( 'cgi-bin', '.', '..' );
    $dh = @opendir( $path );
    while( false !== ( $file = readdir( $dh ) ) ){
        if( !in_array( $file, $ignore ) ){
            $spaces = str_repeat( ' ', ( $level * 4 ) );
            if( is_dir( "$path/$file" ) ){
                echo "$spaces $file\n";
                getDirectory( "$path/$file", ($level+1) );
            } else {
                echo "$spaces $file\n";
            }
        }
    }
    closedir( $dh );
}
getDirectory( "." );  

это правильно воспроизводит файлы/папки.

теперь я нашел это:

$t = system('find');
print_r($t);

который также находит все папки и файлы, тогда я могу создать массив, похожий на первый код.

Я думаю, что system('find'); быстрее, чем readdir, но я хочу знать, хорошая ли это практика? большое спасибо

4b9b3361

Ответ 1

Здесь мой бенчмарк использует простой цикл for с 10 итерациями на моем сервере:

$path = '/home/clad/benchmark/';
// this folder has 10 main directories and each folder as 220 files in each from 1kn to 1mb

// glob no_sort = 0.004 seconds but NO recursion
$files = glob($path . '/*', GLOB_NOSORT);

// 1.8 seconds - not recommended
exec('find ' . $path, $t);
unset($t);

// 0.003 seconds
if ($handle = opendir('.')) {
 while (false !== ($file = readdir($handle))) {
  if ($file != "." && $file != "..") {
   // action
  }
 }
 closedir($handle);
}

// 1.1 seconds to execute
$path = realpath($path);
$objects = new RecursiveIteratorIterator(
 new RecursiveDirectoryIterator($path), RecursiveIteratorIterator::SELF_FIRST);
  foreach($objects as $name => $object) {
   // action
  }
}

Очевидно, что readdir быстрее используется специально, если у вас много трафика на вашем сайте.

Ответ 2

'find' не является переносимым, это команда unix/linux. readdir() переносится и будет работать в Windows или любой другой ОС. Более того, "найти" без каких-либо параметров является рекурсивным, поэтому, если вы находитесь в директории с большим количеством субдисков и файлов, вы увидите их все, а не только содержимое этого пути $.