首页 > 后端开发 > C++ > 正文

C++文件搜索功能 目录递归搜索算法

P粉602998670
发布: 2025-08-31 10:25:01
原创
475人浏览过
答案:使用C++17的std::filesystem实现递归文件搜索,通过recursive_directory_iterator遍历目录树,匹配文件名并收集结果。支持通配符搜索、深度控制及异常处理,代码简洁且跨平台兼容。

c++文件搜索功能 目录递归搜索算法

实现C++中的文件搜索功能,尤其是支持目录递归搜索,核心在于遍历目录树并匹配文件名或路径。以下是基于标准库(C++17起支持

<filesystem>
登录后复制
)的简洁、实用的递归搜索算法实现。

使用 <filesystem> 实现递归搜索

C++17 引入的

std::filesystem
登录后复制
提供了跨平台的目录遍历能力,是实现文件搜索的首选方式。

基本思路:从根目录开始,递归访问每个子目录,检查每个条目是否为文件且文件名匹配目标名称。

示例代码:

#include <iostream>
#include <filesystem>
#include <vector>
#include <string>

namespace fs = std::filesystem;

std::vector<fs::path> search_files(const fs::path& root, const std::string& target_name) {
    std::vector<fs::path> results;

    // 使用 recursive_directory_iterator 遍历所有子目录
    for (const auto& entry : fs::recursive_directory_iterator(root)) {
        if (entry.is_regular_file() && entry.path().filename() == target_name) {
            results.push_back(entry.path());
        }
    }

    return results;
}

int main() {
    fs::path root_dir = "/path/to/search";  // 修改为实际路径
    std::string filename = "example.txt";

    auto found_files = search_files(root_dir, filename);

    if (found_files.empty()) {
        std::cout << "未找到文件: " << filename << "\n";
    } else {
        std::cout << "找到 " << found_files.size() << " 个文件:\n";
        for (const auto& path : found_files) {
            std::cout << path << "\n";
        }
    }

    return 0;
}
登录后复制

支持通配符或部分匹配

如果需要模糊搜索(如包含某关键字的文件名),可以扩展匹配逻辑。

立即学习C++免费学习笔记(深入)”;

例如,检查文件名是否包含目标字符串:

AssemblyAI
AssemblyAI

转录和理解语音的AI模型

AssemblyAI 65
查看详情 AssemblyAI

if (entry.is_regular_file()) {
    std::string filename = entry.path().filename().string();
    if (filename.find(target_name) != std::string::npos) {
        results.push_back(entry.path());
    }
}
登录后复制

控制递归深度或过滤条件

有时需要限制搜索深度或跳过某些目录(如隐藏目录、版本控制文件夹)。

可以通过手动递归实现更精细控制:

void search_recursive(const fs::path& current, const std::string& target, std::vector<fs::path>& results) {
    if (!fs::is_directory(current)) return;

    for (const auto& entry : fs::directory_iterator(current)) {
        try {
            if (entry.is_directory()) {
                // 跳过隐藏目录或特定文件夹
                if (entry.path().filename().string().starts_with(".")) continue;
                search_recursive(entry.path(), target, results);  // 递归进入
            }
            else if (entry.is_regular_file() && entry.path().filename() == target) {
                results.push_back(entry.path());
            }
        } catch (const fs::filesystem_error&) {
            // 忽略权限不足等错误
            continue;
        }
    }
}
登录后复制

性能与异常处理建议

大目录搜索可能耗时,建议:

  • 加入进度提示或异步执行
  • 捕获
    filesystem_error
    登录后复制
    避免因权限问题导致程序崩溃
  • 使用
    std::string_view
    登录后复制
    优化字符串比较(C++17以上)
  • 若需频繁搜索,可考虑建立索引

基本上就这些。C++17 的

filesystem
登录后复制
让目录操作变得简单可靠,递归搜索只需几行核心代码。注意路径格式在不同系统下的兼容性,开发时建议使用相对路径测试。不复杂但容易忽略的是异常处理和符号链接的循环引用问题。

以上就是C++文件搜索功能 目录递归搜索算法的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号