std::experimental::filesystem::hard_link_count
来自cppreference.com
< cpp | experimental | fs
在标头 <experimental/filesystem> 定义
|
||
std::uintmax_t hard_link_count( const path& p ); std::uintmax_t hard_link_count( const path& p, error_code& ec ); |
(1) | (文件系统 TS) |
返回由路径 p 所标定的文件系统对象的硬链接数。
当发生错误时无抛出重载返回 static_cast<uintmax_t>(-1)。
参数
p | - | 要检查的路径 |
ec | - | 用于无抛出重载中报告错误的输出形参 |
返回值
p 的硬链接数。
异常
不接受 error_code& 形参的重载,在发生底层 OS API 错误时抛出 filesystem_error,它以 p 为第一实参并以 OS 错误码为错误码实参构造。如果内存分配失败,则可抛出 std::bad_alloc。接受 error_code& 形参的重载,当 OS API 调用失败时将之设置为 OS API 错误码,而未发生错误时执行 ec.clear()。此重载具有noexcept 规定:
noexcept
示例
运行此代码
#include <experimental/filesystem> #include <iostream> namespace fs = std::experimental::filesystem; int main() { // 在 POSIX 风格的文件系统上,每个目录至少具有 2 个硬链接: // 其自身和特殊成员路径名 "." fs::path p = fs::current_path(); std::cout << "Number of hard links for current path is " << fs::hard_link_count(p) << '\n'; // 每个 ".." 均为父目录的硬链接,因此任何目录的硬链接综述为 2 加上直接子目录数 p = fs::current_path() / ".."; // 每个“点点”均为父目录的硬链接 std::cout << ".. 的硬链接数为 " << fs::hard_link_count(p) << '\n'; }
输出:
当前路径的硬链接数为 2 .. 的硬链接数为 3
参阅
创建一个硬链接 (函数) |