首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将文件夹递归作为树输出的最快和最简单的方法

将文件夹递归作为树输出的最快和最简单的方法
EN

Stack Overflow用户
提问于 2015-08-26 02:40:13
回答 1查看 48关注 0票数 0

有更好的方法(更快)来做同样的事情吗?如果有很多文件夹。

我对算法了解一点,我希望有人能给我一个更好的算法。

我使用代码完成了以下工作:

代码语言:javascript
复制
        private static void ShowAllFoldersUnder(string path, int indent)
        {
            try
            {
                if ((File.GetAttributes(path) & FileAttributes.ReparsePoint)
                    != FileAttributes.ReparsePoint)
                {
                    foreach (string folder in Directory.GetDirectories(path))
                    {
                        Console.WriteLine(
                            "{0}{1}", new string(' ', indent), Path.GetFileName(folder));
                        ShowAllFoldersUnder(folder, indent + 2);
                    }
                }
            }
            catch (UnauthorizedAccessException ex) {
                Console.WriteLine(ex.Message); 
            }    
        }

输出样本结果

代码语言:javascript
复制
CompositeUI
  BuilderStrategies
  Collections
  Commands
  Configuration
    Xsd
  EventBroker
  Instrumentation
  obj
    Debug
      TempPE
  Properties
  Services
  SmartParts
  UIElements
  Utility
  Visualizer
EN

回答 1

Stack Overflow用户

发布于 2015-08-26 03:19:36

EnumerateDirectories可能更快,因为它不必像GetDirectories那样分配文件夹名数组。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32217137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档