0

0

c++中如何获取当前可执行文件的路径_c++获取程序所在目录【实例】

冰火之心

冰火之心

发布时间:2026-01-16 14:44:02

|

742人浏览过

|

来源于php中文网

原创

Linux/macOS 用 readlink("/proc/self/exe") 获取可执行路径,需用 PATH_MAX 缓冲区并检查返回值;Windows 用 GetModuleFileNameA(NULL),缓冲区用 MAX_PATH 并处理失败;跨平台推荐 std::filesystem(C++17)或手动解析目录。

c++中如何获取当前可执行文件的路径_c++获取程序所在目录【实例】

Linux/macOS 下用 /proc/self/exe 读取可执行文件路径

Linux 和 macOS(基于 Darwin)都支持通过 /proc/self/exe 符号链接获取当前进程的可执行文件绝对路径。这是最可靠、无需额外依赖的方式。

注意:该路径是符号链接,需用 readlink 解析为真实路径;且 /proc 是 Linux 特有,macOS 实际走的是 /proc/self/path/a.out 的兼容层(但通常仍可用 /proc/self/exe)。

  • 必须包含 readlink)和 PATH_MAX
  • 缓冲区大小不能硬写 256 —— PATH_MAX 才是安全上限
  • 要检查 readlink 返回值,失败时返回空字符串或抛异常,不能直接用未初始化内存
char path[PATH_MAX];
ssize_t len = readlink("/proc/self/exe", path, sizeof(path) - 1);
if (len == -1) {
    // 处理错误,如权限不足或 /proc 不可用
    return "";
}
path[len] = '\0';
// 此时 path 是完整可执行文件路径,如 "/home/user/app"

Windows 下用 GetModuleFileNameA 获取路径

Windows 没有 /proc,标准做法是调用 GetModuleFileNameA 并传入 NULL 模块句柄,它会返回当前可执行文件的完整路径。

关键点:函数返回的是 ANSI 字符串(非 Unicode),若项目启用了 Unicode 宏(UNICODE),应改用 GetModuleFileNameW 并处理宽字符转换;但多数跨平台项目倾向统一用 UTF-8,所以先用 A 版本再转码更可控。

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

AskAI
AskAI

无代码AI模型构建器,可以快速微调GPT-3模型,创建聊天机器人

下载
  • 需包含
  • 缓冲区大小建议用 MAX_PATH(260),但实际路径可能超长,可用 GetLongPathNameA 补偿
  • 返回值为 0 表示失败,需用 GetLastError() 判断原因(如缓冲区太小)
char path[MAX_PATH];
DWORD len = GetModuleFileNameA(NULL, path, sizeof(path));
if (len == 0 || len >= sizeof(path)) {
    return "";
}
path[len] = '\0';
// path 现在是类似 "C:\\Users\\user\\app.exe" 的字符串

提取目录部分要用 dirname(POSIX)或手动截断(Windows)

拿到完整路径后,真正需要的是“程序所在目录”,不是可执行文件本身。POSIX 系统可直接用 dirname,但它会修改原字符串 —— 必须传入可修改的副本;Windows 没有等价 API,得自己找最后一个 '\\''/' 并置零。

  • dirname 返回的是指向原缓冲区内部的指针,不可直接返回(局部数组生命周期结束就悬空)
  • Windows 下建议统一用 strrchr 查找分隔符,比硬编码索引更健壮(支持正斜杠/反斜杠混用)
  • 路径末尾的 /\\ 是否保留?按惯例保留更安全(避免后续拼接时漏掉分隔符)
// Linux/macOS 示例(使用 dirname 后需 strcpy)
char full_path[PATH_MAX];
// ... 先填入完整路径
char *dir = dirname(strdup(full_path)); // strdup 避免修改原缓冲区
std::string dir_str(dir);
free(dir); // 注意释放 strdup 分配的内存

C++ 跨平台封装要注意路径分隔符与编码一致性

混合使用 /\\ 在运行时一般不影响打开文件(系统层会识别),但若用于日志、配置拼接或调试输出,不统一容易引发混淆。更麻烦的是编码:Windows 默认 ANSI(系统 locale),Linux/macOS 默认 UTF-8 —— 如果路径含中文,直接用 char* 可能乱码。

  • 推荐用 std::filesystem::current_path().parent_path() 替代手工解析(C++17 起),它自动处理分隔符和编码,但需确认目标平台 STL 支持度
  • 若不能用 C++17,至少把路径字符串统一转成 std::string,并在 Windows 上用 MultiByteToWideChar + WideCharToMultiByte 强制转 UTF-8
  • 不要假设 argv[0] 可靠:它可能被修改、不含路径、甚至为空(某些启动方式下)

最常被忽略的一点:容器化环境(Docker)或沙盒(Flatpak/Snap)中,/proc/self/exe 可能指向绑定挂载路径或符号链接链很长,readlink 只解一层 —— 此时应循环调用直到得到真实路径,或改用 realpath

相关专题

更多
string转int
string转int

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

315

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

231

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

436

2024.03.01

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

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

257

2023.08.03

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

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

208

2023.09.04

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

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

1465

2023.10.24

字符串介绍
字符串介绍

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

619

2023.11.24

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

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

550

2024.03.22

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

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

精品课程

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

共48课时 | 7.3万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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