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 ); |
(filesystem 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"
[编辑] 参见
检查参数是否指向符号链接 (function) | |
创建符号链接 (function) | |
复制符号链接 (function) | |
确定文件属性 确定文件属性,检查符号链接目标 (function) |