0

0

c++如何判断文件是否存在_c++ filesystem库用法

尼克

尼克

发布时间:2026-01-01 18:52:02

|

188人浏览过

|

来源于php中文网

原创

最推荐用 std::filesystem::exists() 判断文件是否存在,C++17 起原生支持;需注意权限不足时也返回 false,应结合 status() 和 error_code 诊断;区分文件与目录须叠加 is_regular_file() 等类型检查;路径拼接应使用 path / 操作符而非手动字符串拼接。

c++如何判断文件是否存在_c++ filesystem库用法

std::filesystem::exists() 判断文件是否存在

这是最直接、最推荐的方式,C++17 起标准库原生支持,无需第三方依赖。它能准确区分“文件不存在”“路径存在但不是文件”(比如是目录)以及“权限不足导致无法访问”等情形。

注意:std::filesystem::exists() 返回 false 并不总代表文件一定不存在——如果当前进程无权读取父目录(例如权限为 drwx------),它也可能返回 false,此时需结合 std::filesystem::status() 或错误码进一步判断。

  • 必须在编译时启用 C++17 或更高标准(如 -std=c++17
  • 需要包含头文件:#include
  • 多数编译器要求链接 -lstdc++fs(GCC 早期版本),Clang 10+ 和 MSVC 通常自动处理
#include 
#include 

int main() {
    std::filesystem::path p = "config.json";
    if (std::filesystem::exists(p)) {
        std::cout << "文件存在\n";
    } else {
        std::cout << "文件不存在或不可访问\n";
    }
}

区分文件和目录:用 is_regular_file()is_directory()

仅知道“存在”不够常见——你往往需要确认它是不是一个普通文件(而非目录、符号链接、设备节点等)。这时候不能只靠 exists(),得叠加类型判断。

exists() 对目录也返回 true,所以直接用它判断“配置文件是否存在”可能误判一个同名目录。安全做法是先 exists(),再 is_regular_file()

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

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载
  • std::filesystem::is_regular_file(p):仅当 p 是普通文件且存在时返回 true;若 p 是目录、不存在、或不可访问,都返回 false
  • std::filesystem::is_directory(p) 同理,专用于检测目录
  • 两者都隐式调用 exists(),但建议显式检查 exists() 再判断类型,便于调试失败原因
auto p = std::filesystem::path("data.csv");
if (std::filesystem::exists(p) && std::filesystem::is_regular_file(p)) {
    // 确保是可读的普通文件
    std::cout << "data.csv 是一个普通文件\n";
}

跨平台路径拼接别手写斜杠:用 std::filesystem::path 构造

手动拼接路径字符串(如 "./" + name + ".txt")容易出错,尤其在 Windows 下混用 /\ 可能导致 exists() 返回 false 即使文件真实存在。

std::filesystem::path 会自动处理分隔符归一化(Windows 下转为 \,其他平台转为 /),并支持重载 / 操作符拼接:

  • 正确:std::filesystem::path{"dir"} / "file.txt" → 自动适配平台
  • 错误:"dir/file.txt" 在 Windows 上可能被当作相对路径解析失败(尤其涉及驱动器号时)
  • 避免使用 .string() 提前转成 std::string,除非必要;保持 path 类型更安全
std::filesystem::path base = "/tmp";
std::filesystem::path full = base / "cache" / "index.bin"; // 自动处理分隔符
if (std::filesystem::is_regular_file(full)) {
    // ...
}

权限不足时如何诊断?捕获 std::filesystem::filesystem_error

当路径所在目录没有执行(x)权限(Linux/macOS)或遍历权限(Windows),exists() 默认静默返回 false,不暴露底层错误。要看到具体原因,必须启用异常模式并捕获异常。

默认情况下,std::filesystem 函数不抛异常,而是通过 std::error_code& 参数返回错误。但你可以主动开启异常行为:

  • 调用前设全局策略:std::filesystem::current_path(); 不影响,但可强制触发一次权限检查
  • 更可靠方式:传入 std::error_code 参数,检查是否非空
  • 或者,用 std::filesystem::status(p, ec) 替代 exists(),它返回完整状态对象,ec 包含错误细节
std::error_code ec;
auto s = std::filesystem::status("restricted_dir/test.txt", ec);
if (ec) {
    std::cerr << "stat 失败: " << ec.message() << "\n"; // 如 "Permission denied"
} else if (s.type() == std::filesystem::file_type::regular) {
    std::cout << "是普通文件\n";
}
C++ 的 filesystem 库看似简单,但路径解析、权限语义、符号链接处理这些细节在不同系统上差异明显。最容易忽略的是:不检查 error_code 就断言“文件不存在”,实际上可能是权限、挂载点失效或 NFS 超时导致的假阴性。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

249

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

547

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

539

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

158

2025.07.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

热门下载

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

精品课程

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

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

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

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