博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
理解 Delphi 的类(十) - 深入方法[28] - 递归函数实例: 搜索当前目录下的所有嵌套目录...
阅读量:6842 次
发布时间:2019-06-26

本文共 1399 字,大约阅读时间需要 4 分钟。

  hot3.png

//上面一个例子不能说明递归函数的本质, 直接来个实用的函数吧, 刚好要用.unit Unit1;interfaceuses  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,  Dialogs, StdCtrls;type  TForm1 = class(TForm)    Button1: TButton;    Memo1: TMemo;    procedure Button1Click(Sender: TObject);  end;var  Form1: TForm1;implementation{$R *.dfm}//列出一个目录下所有目录(包括嵌套)的函数procedure GetDirs(dirName: string; List: TStrings);var  SRec: TSearchRec;            {定义 TSearchRec 结构变量}  dir: string;const  attr: Integer = faDirectory; {文件属性常量, 表示这是文件夹}begin  dirName := ExcludeTrailingBackslash(dirName) + '\'; {不知道最后是不是 \; 先去掉, 再加上}  dir := dirName + '*.*'; {加上 \; *.* 或 * 表示所有文件, 系统会把目录也当作一个文件}  if FindFirst(dir, attr, SRec) = 0 then {开始搜索,并给 SRec 赋予信息, 返回0表示找到第一个}  begin    repeat      if (SRec.Attr = attr) and              {如果是文件夹}         (SRec.Name <> '.') and              {排除上层目录}         (SRec.Name <> '..') then            {排除根目录}       begin         List.Add(dirName + SRec.Name);      {用List记下结果}         GetDirs(dirName + SRec.Name, List); {这句就是递归调用, 如果没有这句, 只能搜索当前目录}       end;    until(FindNext(SRec)<>0);                {找下一个, 返回0表示找到}  end;  FindClose(SRec);                           {结束搜索}end;{测试}procedure TForm1.Button1Click(Sender: TObject);var  list: TStrings;begin  list := TStringList.Create;  GetDirs('C:\Downloads', list);  Memo1.Lines := list;  list.Free;end;end.

转载于:https://my.oschina.net/hermer/blog/319514

你可能感兴趣的文章