std::experimental::filesystem::read_symlink
来自 cppreference.com
< cpp | experimental | fs
定义在头文件 <experimental/filesystem> 中 |
||
path read_symlink( const path& p ); path read_symlink( const path& p, error_code& ec ); |
(文件系统 TS) | |
如果路径 p 指向符号链接,则返回一个指向该符号链接目标的新路径对象。
如果 p 不指向符号链接,则会发生错误。
非抛出重载在错误时返回空路径。
内容 |
[编辑] 参数
p | - | 指向符号链接的路径 |
ec | - | 非抛出重载中用于错误报告的输出参数 |
[编辑] 返回值
符号链接的目标(可能不存在)。
[编辑] 异常
不使用 error_code& 参数的重载在底层操作系统 API 错误时抛出 filesystem_error,并使用 p 作为第一个参数,以及操作系统错误代码作为错误代码参数来构建。 std::bad_alloc 可能会在内存分配失败时抛出。使用 error_code& 参数的重载在操作系统 API 调用失败时将其设置为操作系统 API 错误代码,并在没有错误发生时执行 ec.clear()。此重载具有noexcept 规范:
noexcept
[编辑] 示例
运行此代码
#include <experimental/filesystem> #include <iostream> namespace fs = std::experimental::filesystem; int main() { // on a typical Linux system, /lib/libc.so.6 is a symlink fs::path p = "/lib/libc.so.6"; if (exists(p) && is_symlink(p)) std::cout << p << " -> " << read_symlink(p) << '\n'; else std::cout << p << " does not exist or is not a symlink\n"; }
可能输出
"/lib/libc.so.6" -> "libc-2.12.so"
[编辑] 另请参阅
检查参数是否指向符号链接 (函数) | |
创建符号链接 (函数) | |
复制符号链接 (函数) | |
确定文件属性 确定文件属性,检查符号链接目标 (函数) |