ftw nftw遍历目录

       #include
       int ftw(const char *dir, int (*fn)(const char *file, const struct stat *sb, int flag), int nopenfd);
       int nftw(const char *dir, int (*fn)(const char *file, const struct stat *sb, int flag, struct FTW *s), int nopenfd, int flags);

ftw与ntfw遍历目录时几乎是一样的,除了最后一个参数flags。

ftw() 会从参数dir指定的目录开始,往下一层层地递归式遍历子目录。ftw()会传三个参数给fn(), 第一个参数*file指向当时所在的目录路径,第二个参数是*sb, stat结构指针,第三个参数为旗标,有下面几种可能值
FTW_F        
一般文件
FTW_D       
目录
FTW_DNR    
不可读取的目录,此目录以下将不被遍历
FTW_SL       
符号连接
FTW_NS       
无法取得stat结构数据,有可能是权限问题

      最后一个参数depth代表ftw()在进行遍历目录时同时打开的文件数。ftw()在遍历时每一层目录至少需要一个文件描述词,如果遍历时用完了depth所给予的限制数目,整个遍历将因不断地关文件和开文件操作而显得缓慢
      
如果要结束ftw()的遍历,fn()只需返回一非零值即可,此值同时也会是ftw()的返回值。否则ftw()会试着走完所有的目录,然后返回0

  值:遍历中断则返回fn()函数的返回值,全部遍历则返回0,若有错误发生则返回-1
附加说明:由于ftw()会动态配置内存使用,请使用正常方式(fn函数返回非零值)来中断遍历,不要在fn函数中使用longjmp()



nftw()ftw()很像,都是从参数dir指定的目录开始,往下一层层地递归遍历子目录。每进入一个目录,便会调用参数*fn定义的函数来处理。nftw()会传四个参数给fn(). 第一个参数*file指向当时所在的目录路径,第二个参数是*sb, stat结构指针(结构定义请参考stat()),第三个参数为旗标,有底下几种可能值:
FTW_F                         
一般文件
FTW_D                         
目录
FTW_DNR                      
不可读取的目录。此目录以下将不被遍历
FTW_SL                         
符号连接
FTW_NS                        
无法取得stat结构数据,在可能是权限问题
FTW_DP                        
目录,而且子目录都已被遍历过了
FTW_SLN                       
符号连接,但连接不存在的文件

fn()
的第四个参数是FTW结构,定义如下:

struct  FTW
{
     int  base;
     int  level; //level
代表遍历时的深度
}

nftw()
第三个参数depth代表nftw()在进行遍历目录时可同时打开的文件数。
ftw()
在遍历时每一层目录至少需要一个文件描述词,如果遍历时用完了depth所给予的限制数目,整个遍历将因不断地关文件和开文件操作而显得的缓慢

nftw()
最后一个参数flags用来指定遍历时的动作,可指定下列的操作或用OR组合
FTW_CHDIR                 
在读目录之前先用chdir()移到此目录
FTW_DEPTH                
执行深度优先搜索。在遍历此目录前先将所有子目录遍历完
FTW_MOUNT               
遍历时不要跨越到其他文件系统
FTW_PHYS                  
不要遍历符号连接的目录。预设会遍历符号连接目录

如果要结束nftw()的遍历,fn()只需返回一非0值即可,此值同时也会是nftw()的返回值。否则nftw()会试着遍历完所有目录,然后返回0

:遍历中断则返回fn()函数的返回值,全部遍历完则返回0,若有错误发生则返回-1


网络上有些说法是ftw 对于每一个文件他都会调用stat函数,这就造成程序会跟随符号链接。这就可能导致在某些情况下重复某些目录或者循环统计某些目录文件。实际测试建立以下几个目录关系。发现实际并未出现循环统计及重复目录的情况。且nftw的man文档中也指出,即使跟随连接也不会出现文件被重复计数的情况。

 FTW_PHYS
              If set, do not follow symbolic links.  (This is what you want.)  If not set, symbolic links are followed, but no file is reported twice.

另测试发现如果一个软连接指向自己,ftw也会返回-1;且此时不会调用fn函数。



你可能感兴趣的:(ftw nftw遍历目录)