std::filesystem::read_symlink
來自 cppreference.com
< cpp | filesystem
定義於標頭檔案 <filesystem> |
||
std::filesystem::path read_symlink( const std::filesystem::path& p ); |
(1) | (C++17 起) |
std::filesystem::path read_symlink( const std::filesystem::path& p, std::error_code& ec ); |
(2) | (C++17 起) |
如果路徑 p 指向一個符號連結,則返回一個指向該符號連結目標的新的路徑物件。
如果 p 不指向符號連結,則會發生錯誤。
不丟擲異常的過載在發生錯誤時返回一個空路徑。
目錄 |
[編輯] 引數
p | - | 符號連結的路徑 |
ec | - | 非丟擲過載中用於錯誤報告的出參 |
[編輯] 返回值
符號連結的目標(可能不存在)。
[編輯] 異常
任何未標記為 noexcept
的過載都可能在記憶體分配失敗時丟擲 std::bad_alloc。
[編輯] 示例
執行此程式碼
#include <filesystem> #include <iostream> namespace fs = std::filesystem; int main() { for (fs::path p : {"/usr/bin/gcc", "/bin/cat", "/bin/mouse"}) { std::cout << p; fs::exists(p) ? fs::is_symlink(p) ? std::cout << " -> " << fs::read_symlink(p) << '\n' : std::cout << " exists but it is not a symlink\n" : std::cout << " does not exist\n"; } }
可能的輸出
"/usr/bin/gcc" -> "gcc-5" "/bin/cat" exists but it is not a symlink "/bin/mouse" does not exist
[編輯] 參閱
(C++17) |
檢查引數是否引用符號連結 (函式) |
(C++17)(C++17) |
建立符號連結 (函式) |
(C++17) |
複製一個符號連結 (函式) |
(C++17)(C++17) |
確定檔案屬性 確定檔案屬性,檢查符號連結目標 (函式) |