將printf 與std::string 一起使用時感到困惑是可以理解的,如看起來它們應該無縫地協同工作,因為string 是std 命名空間的成員。然而,由於 printf 的類型不安全性質,情況並非如此。
Printf 使用 C 意義上的可變參數,這意味著您可以傳遞任意數量的參數,但它依賴於您告訴它這些參數的數量和類型。對於 printf,這是透過帶有編碼類型資訊的字串來完成的,例如 int 的 %d。如果你對參數的類型或數量撒謊,則該函數沒有標準的認知方式,並且會表現出未定義的行為。
對於 std::string(一種類型安全的 C 構造),printf 沒有選擇對於它來說,只有一個 C 風格的字串。使用其他東西來代替它所期望的肯定不會給你想要的結果。
解決這個問題的一個簡單方法是使用std::cout 正常列印,因為std::string 支援此操作符重載目的:
std::cout << "Follow this command: " << myString;
如果由於某種原因需要提取C風格的字串,可以使用std::string的c_str()方法來取得一個const char *是空終止的。以下是使用 c_str() 的更新範例:
printf("Follow this command: %s", myString.c_str()); // note the use of c_str
對於行為類似 printf 的型別安全函數,請考慮使用可變參數範本(在 C 11 中引入)。您可以在[此處](https://en.cppreference.com/w/cpp/utility/variadic)找到一個範例。此外,Boost 還提供了一個可能有用的函式庫,稱為 boost::format。
以上是為什麼 printf 不直接與 std::string 一起工作,有什麼替代方案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!