std::experimental::filesystem::create_symlink, std::experimental::filesystem::create_directory_symlink
來自 cppreference.com
< cpp | experimental | fs
定義於標頭檔案 <experimental/filesystem> |
||
void create_symlink( const path& target, const path& link ); void create_symlink( const path& target, const path& link, error_code& ec ); |
(1) | (檔案系統 TS) |
void create_directory_symlink( const path& target, const path& link ); void create_directory_symlink( const path& target, const path& link, error_code& ec ); |
(2) | (檔案系統 TS) |
建立一個符號連結 link,其目標設定為 target,如同透過 POSIX symlink():路徑名 target 可能無效或不存在。
某些作業系統要求符號連結建立時識別連結是否為目錄。可移植程式碼應使用 (2) 建立目錄符號連結,而不是 (1),儘管在 POSIX 系統上沒有區別。
目錄 |
[編輯] 引數
target | - | 符號連結指向的路徑,無需存在 |
link | - | 新符號連結的路徑 |
ec | - | 非丟擲過載中用於錯誤報告的出參 |
[編輯] 返回值
(無)
[編輯] 異常
不帶 error_code& 引數的過載會在底層 OS API 錯誤時丟擲 filesystem_error,該錯誤使用 target 作為第一個引數,link 作為第二個引數,OS 錯誤碼作為錯誤碼引數構造。如果記憶體分配失敗,可能會丟擲 std::bad_alloc。帶 error_code& 引數的過載在 OS API 呼叫失敗時將其設定為 OS API 錯誤碼,並且在沒有錯誤發生時執行 ec.clear()。此過載具有noexcept 規範:
noexcept
[編輯] 注意
某些作業系統根本不支援符號連結,或者只支援常規檔案的符號連結。
某些檔案系統不支援符號連結,無論作業系統如何,例如某些儲存卡和快閃記憶體驅動器上使用的 FAT 系統。
像硬連結一樣,符號連結允許檔案擁有多個邏輯名稱。硬連結的存在保證了檔案的存在,即使原始名稱已被刪除。符號連結不提供此類保證;事實上,當建立連結時,target 引數指定的檔案不一定存在。符號連結可以跨越檔案系統邊界。
[編輯] 示例
執行此程式碼
#include <experimental/filesystem> #include <iostream> namespace fs = std::experimental::filesystem; int main() { fs::create_directories("sandbox/subdir"); fs::create_symlink("target", "sandbox/sym1"); fs::create_directory_symlink("subdir", "sandbox/sym2"); for (auto it = fs::directory_iterator("sandbox"); it != fs::directory_iterator(); ++it) if (is_symlink(it->symlink_status())) std::cout << *it << "->" << read_symlink(*it) << '\n'; fs::remove_all("sandbox"); }
可能的輸出
"sandbox/sym1"->"target" "sandbox/sym2"->"subdir"
[編輯] 參閱
確定檔案屬性 確定檔案屬性,檢查符號連結目標 (函式) | |
獲取符號連結的目標 (函式) | |
建立硬連結 (函式) |