std::experimental::filesystem::read_symlink
来自 cppreference.cn
< 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"
[编辑] 另请参阅
检查参数是否引用符号链接 (函数) | |
创建符号链接 (函数) | |
复制一个符号链接 (函数) | |
确定文件属性 确定文件属性,检查符号链接目标 (函数) |