命名空间
变体
操作

std::filesystem::absolute

来自 cppreference.cn
 
 
 
定义于头文件 <filesystem>
path absolute( const std::filesystem::path& p );
(1) (since C++17)
path absolute( const std::filesystem::path& p, std::error_code& ec );
(2) (since C++17)

返回一个路径,该路径引用与 p 相同的文件系统位置,且 filesystem::path::is_absolute()true

2) 如果发生错误,此非抛出重载将返回默认构造的路径。

目录

[编辑] 参数

p - 要转换为绝对路径形式的路径
ec - 非抛出重载中用于错误报告的输出参数

[编辑] 返回值

返回一个绝对(尽管不一定是规范的)路径名,该路径名引用与 p 相同的文件。

[编辑] 异常

任何未标记为 noexcept 的重载都可能在内存分配失败时抛出 std::bad_alloc

1) 在底层操作系统 API 错误时抛出 std::filesystem::filesystem_error,并使用 p 作为第一个路径参数,以及操作系统错误代码作为错误代码参数构造。
2) 如果操作系统 API 调用失败,则将 std::error_code& 参数设置为操作系统 API 错误代码;如果未发生错误,则执行 ec.clear()

[编辑] 注解

鼓励实现不要将 p 不存在视为错误。

对于基于 POSIX 的操作系统,std::filesystem::absolute(p) 等效于 std::filesystem::current_path() / p,除非 p 是空路径。

对于 Windows,std::filesystem::absolute 可能实现为调用 GetFullPathNameW

[编辑] 示例

#include <filesystem>
#include <iostream>
namespace fs = std::filesystem;
 
int main()
{
    std::filesystem::path p = "foo.c";
    std::cout << "Current path is " << std::filesystem::current_path() << '\n';
    std::cout << "Absolute path for " << p << " is " << fs::absolute(p) << '\n';
}

可能的输出

Current path is "/tmp/1666297965.0051296"
Absolute path for "foo.c" is "/tmp/1666297965.0051296/foo.c"

[编辑] 参见

构成规范路径
(函数) [编辑]
构成相对路径
(函数) [编辑]