std::string과 함께 printf를 사용할 때 혼동되는 것은 이해할 수 있습니다. string은 std 네임스페이스의 구성원이므로 원활하게 함께 작동해야 하는 것처럼 보일 수 있습니다. 그러나 printf의 유형이 안전하지 않은 특성으로 인해 그렇지 않습니다.
Printf는 C 의미에서 가변 인수를 사용합니다. 해당 인수의 수와 유형. printf의 경우 이는 int의 경우 %d와 같이 인코딩된 유형 정보가 있는 문자열을 통해 수행됩니다. 인수의 유형이나 수에 대해 거짓말을 하면 함수는 알 수 있는 표준 방법이 없으며 정의되지 않은 동작을 나타냅니다.
유형이 안전한 C 구조인 std::string을 사용하면 printf에 옵션이 없습니다. 이를 위해서는 C 스타일 문자열만 사용됩니다. 예상한 것 대신에 다른 것을 사용하면 확실히 원하는 결과를 얻을 수 없습니다.
이 문제에 대한 쉬운 해결 방법은 std::cout을 사용하여 정상적으로 인쇄하는 것입니다. 왜냐하면 std::string은 이에 대한 연산자 오버로딩을 지원하기 때문입니다. 목적:
std::cout << "Follow this command: " << myString;
어떤 이유로 C 스타일 문자열을 추출해야 하는 경우 std::string의 c_str() 메서드를 사용하여 const char *를 가져올 수 있습니다. 이는 null로 종료됩니다. 다음은 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!