std::experimental::filesystem::absolute, std::experimental::filesystem::system_complete
来自cppreference.com
| 在标头 <experimental/filesystem> 定义
|
||
| |
(1) | (文件系统 TS) |
| |
(2) | (文件系统 TS) |
1) 返回根据以下规则
p 相对于 base 的绝对路径:
- 若
p同时具有根名称和根目录(例如"C:\users"),则返回该路径且无修改。 - 若
p具有根名称,其后未跟着根目录(例如"C:text.txt"),则将base插入p的根名称和p的其余部分之间。正式而言,返回p.root_name() / fs::absolute(base).root_directory() / fs::absolute(base).relative_path() / p.relative_path()。 - 若
p没有根名称但有根目录(例如 POSIX 系统上的"/var/tmp/file.txt"或 Windows 上的"\users\ABC\Document.doc"),则将base的根名称(若它有)前附于p(POSIX 系统上不会修改p,而 Windows 系统上,"\users\ABC\Document.doc"变为"C:\users\ABC\Document.doc"。)正式而言,返回fs::absolute(base).root_name() / p。 - 若
p没有根名称和根目录(例如"../file.txt"),则将整个base前附于p。正式而言,返回absolute(base) / p。
- 若
2) 对于给定路径名
p 时 OS 文件打开 API 将要访问的文件,获取标定它的绝对路径。POSIX 系统上,这等价于 (1) 以默认 base(fs::current_path())调用。Windows 系统上,每个逻辑驱动器都有其自身的当前工作目录,因而若 p 尚不是绝对路径并具有根名称成分(例如 "E:filename.txt"),则使用该驱动器的当前工作目录,它可能是由早前执行的程序所设置的。参数
| p | - | 要转换为绝对形式的路径 |
| base | - | 用作起始位置的路径(不必为绝对路径) |
| ec | - | 用于无抛出重载中尽显错误报告的输出参数 |
返回值
返回按上文所述组合 p 和 base 所构成的绝对(但不必是规范的)路径。
异常
不接受 error_code& 形参的重载,在发生底层 OS API 错误时抛出 filesystem_error,它以 p 为第一实参,以 base 为第二实参,并以 OS 错误码为错误码实参构造。如果内存分配失败,则可抛出 std::bad_alloc。接受 error_code& 形参的重载,当 OS API 调用失败时将之设置为 OS API 错误码,而未发生错误时执行 ec.clear()。此重载具有
noexcept 规定:
noexcept注解
在支持根名称的系统上(比如 Windows),在有根名称的相对路径(例如 "D:file.txt")上调用 absolute 的结果,当 base 的根名称与之不同时通常会得到不存在的路径。
示例
Run this code
#include <filesystem>
#include <iostream>
namespace fs = std::experimental::filesystem;
int main()
{
fs::path p = "C:cl.exe";
std::cout << "当前路径为 " << fs::current_path() << '\n'
<< p << " 的绝对路径为 " << fs::absolute(p) << '\n'
<< p << " 的系统完整路径为 "
<< fs::system_complete(p) << '\n';
}
可能的输出:
当前路径为 "D:/local/ConsoleApplication1"
"C:cl.exe" 的绝对路径为 "C:/local/ConsoleApplication1/cl.exe"
"C:cl.exe" 的系统完整路径为 "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\bin\cl.exe"
参阅
| 组成一个规范路径 (函数) |