将 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中文网其他相关文章!