php高效遍历目录文件及子目录,php高效遍历目录文件及子目录

本文探讨了在处理大量目录时,使用递归方式与队列方式的效率差异。递归方式由于函数调用开销,速度相对较慢,而队列方式则能有效提高遍历速度。示例代码分别展示了PHP中两种方法实现的目录遍历函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果目录很多,推荐队列方式,递归方式会慢,慢的原因:递归的实现是通过调用函数本身,函数调用的时候,每次调用时要做地址保存,参数传递等<?php

//递归方式

function read_dir($dir){

$files=array();

$dir_list=scandir($dir);

foreach($dir_list as $file){

if($file!='..' && $file!='.'){

if(is_dir($dir.'/'.$file)){

$files[]=read_dir($dir.'/'.$file);

}else{

$files[]=$file;

}

}

}

return $files;

}

//队列方式

function read_dir_queue($dir){

$files=array();

$queue=array($dir);

while($data=each($queue)){

$path=$data['value'];

if(is_dir($path) && $handle=opendir($path)){

while($file=readdir($handle)){

if($file=='.'||$file=='..') continue;

$files[] = $real_path=$path.'/'.$file;

if (is_dir($real_path)) $queue[] = $real_path;

}

}

closedir($handle);

}

return $files;

}

print_r(read_dir_queue('D:/webroot/suanfa/dir'));exit;

本文转载于:优快云博客,如有侵犯,请联系a@php.cn删除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值