0

0

C++中std::filesystem::exists怎么检测路径_C++判断文件存在新标准【规范】

尼克

尼克

发布时间:2026-02-06 14:11:19

|

460人浏览过

|

来源于php中文网

原创

std::filesystem::exists 默认抛出 filesystem_error 异常而非返回 false,应优先使用带 std::error_code& 参数的重载;对符号链接自动解引用,需确认软链本身存在时改用 symlink_status;Windows 下注意路径标准化与 UNC 可达性;性能低于裸 stat,高频场景需缓存 status。

c++中std::filesystem::exists怎么检测路径_c++判断文件存在新标准【规范】

std::filesystem::exists 会抛异常,不是所有路径都能直接查

std::filesystem::exists 在遇到权限不足、符号链接断裂、路径过长或跨文件系统挂载点不可达等情况时,**默认抛出 std::filesystem::filesystem_error 异常**,而不是返回 false。很多新手误以为它像 C 风格的 access() 那样静默失败。

实际使用必须处理异常,或者改用带 std::error_code& 参数的重载版本:

std::error_code ec;
bool exists = std::filesystem::exists(path, ec);
// ec 为非零值表示出错(如 permission_denied、no_such_file_or_directory)
// 此时 exists 的返回值不可靠,应以 ec 是否为 0 为准
  • 推荐始终使用带 ec 的重载,尤其在服务端或嵌入式等异常处理成本高的场景
  • 若忽略 ec 且路径非法(比如 /proc/self/fd/999),程序直接崩溃
  • 注意:即使 ec 为 0,exists 返回 false 也不代表“一定不存在”——某些只读挂载或 NFS 延迟可能让内核返回 ENOENT 误判

exists 对目录和文件一视同仁,但 symlink_status 更准

std::filesystem::exists 检查的是“路径所指对象是否存在”,对符号链接会自动解引用。这意味着:

  • path 是指向无效目标的软链,exists(path) 返回 false
  • 若只想确认软链本身存在(不管目标是否有效),该函数不适用

此时应改用 std::filesystem::symlink_status

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

Talefy
Talefy

一个AI故事创作和角色扮演平台

下载
std::error_code ec;
auto s = std::filesystem::symlink_status(path, ec);
if (!ec && s.type() != std::filesystem::file_type::not_found) {
    // 路径本身存在(含 broken symlink)
}
  • status()symlink_status()区别关键在是否解引用:前者进到目标里看,后者只看路径这一层
  • 判断“文件是否存在且是普通文件”应组合使用:exists(p, ec) && is_regular_file(p, ec),不能只靠 exists

Windows 下路径分隔符和大小写敏感性要特别注意

Windows 默认不区分大小写,但 std::filesystem 的行为受底层 API 和卷格式影响:

  • NTFS 卷上,exists("C:\\Temp\\File.TXT") 可能返回 true 即使实际文件名是 file.txt
  • 但若路径含非法字符(如 |)或使用正斜杠 / 作为分隔符,部分旧版 MSVC STL 会提前报错,而非交由系统判断
  • 建议统一用 std::filesystem::path 构造路径,它会自动标准化分隔符:std::filesystem::path("a/b/c") 在 Windows 上转为 a\b\c

另外,UNC 路径(如 \\\\server\\share\\file)需确保网络可达,否则 exists 会卡住或超时(取决于系统配置),不是立刻返回 false

性能开销比 stat 略大,高频调用需缓存

std::filesystem::exists 底层通常调用 stat()GetFileAttributesEx(),但额外封装了路径解析、编码转换(如 UTF-8 ↔ UTF-16)、异常对象构造等逻辑。实测比裸 stat 慢 10%–30%。

  • 不要在 tight loop 中反复调用,比如轮询文件生成 —— 改用 inotify(Linux)或 ReadDirectoryChangesW(Windows)
  • 若需多次检查同一路径,可缓存 std::filesystem::status 结果(含 mtimefile_size),避免重复系统调用
  • 注意:缓存状态不解决并发修改问题;若其他进程可能删/改文件,仍需每次重新 check

真正容易被忽略的是:exists 不保证后续操作一定成功 —— 检查完瞬间被删除,open() 仍可能失败。它只是快照,不是锁。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

954

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1138

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

814

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

457

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2355

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

849

2023.08.10

windows boot manager
windows boot manager

windows boot manager无法开机的解决方法:1、系统文件损坏,使用Windows安装光盘或USB启动盘进入恢复环境,选择修复计算机,然后选择自动修复;2、引导顺序错误,进入恢复环境,选择命令提示符,输入命令"bootrec /fixboot"和"bootrec /fixmbr",然后重新启动计算机;3、硬件问题,使用硬盘检测工具进行扫描和修复;4、重装操作系统。本专题还提供其他解决

1731

2023.08.28

windows锁屏快捷键
windows锁屏快捷键

windows锁屏快捷键是Windows键+L、Ctrl+Alt+Del、Windows键+D、Windows键+P和Windows键+R。本专题为大家提供windows相关的文章、下载、课程内容,供大家免费下载体验。

1642

2023.08.30

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.6万人学习

Git 教程
Git 教程

共21课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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