std::filesystem::directory_entry::replace_filename
来自cppreference.com
< cpp | filesystem | directory entry
void replace_filename( const std::filesystem::path& p ); void replace_filename( const std::filesystem::path& p, std::error_code& ec ); |
(C++17 起) | |
更改 directory_entry 的文件名。
等效于以 path.replace_filename(p) 修改路径成员,并调用 refresh 更新缓存的属性。若发生错误,则缓存属性的值是未指定的。
此函数不向文件系统提交任何更改。
参数
p | - | 要附加到当前存储路径的亲路径的路径 |
ec | - | 不抛出重载中报告错误的输出参数 |
返回值
(无)
异常
不接受 std::error_code& 参数的重载在底层 OS API 错误时抛出 filesystem_error ,以第一 path 参数 p
和作为错误码参数的 OS 错误码构造。若 OS API 调用失败,则接受 std::error_code& 参数的重载设置该参数为 OS API 错误码,而若不出现错误则执行 ec.clear() 。若内存分配失败,则任何不标记为 noexcept
的重载可能抛出 std::bad_alloc 。
示例
运行此代码
#include <iostream> #include <filesystem> int main() { namespace fs = std::filesystem; { fs::directory_entry entry{ "omega" }; std::cout << entry << '\n'; entry.replace_filename("alpha"); std::cout << entry << '\n'; }{ fs::directory_entry entry{ "/omega/" }; std::cout << entry << '\n'; entry.replace_filename("alpha"); std::cout << entry << '\n'; } }
输出:
"omega" "alpha" "/omega/" "/omega/alpha"
参阅
赋值内容 (公开成员函数) | |
以另一路径替换最末的路径组分 ( std::filesystem::path 的公开成员函数) |