반환된 문자열에 대해 std::string.c_str() 호출이 실패하는 이유는 무엇입니까?
다음 코드를 고려하십시오.
<code class="cpp">std::string getString() { std::string str("hello"); return str; } int main() { const char* cStr = getString().c_str(); std::cout << cStr << std::endl; // Outputs garbage }</code>
예상할 수 있듯이 getString()은 로컬 문자열의 복사본을 반환하여 main()에서 활성 상태로 유지하는 것처럼 보입니다. 그러나 코드가 예기치 않게 가비지를 인쇄합니다. 이는 반환된 문자열이 언제, 왜 파기되는가에 대한 질문을 제기합니다.
답은 C의 임시 항목 특성에 있습니다. getString()은 함수 내에서 생성되고 반환된 문이 완료되면 삭제되는 임시 std::string을 반환합니다. 즉, cStr이 문자열의 기본 문자 배열을 가리킬 때 임시 항목은 이미 삭제되었으며 cStr은 매달린 포인터가 되어 정의되지 않은 동작으로 이어진다는 의미입니다.
이 문제를 해결하려면 반환된 임시 항목을 다음과 같이 할 수 있습니다. 명명된 변수나 참조에 바인딩되어 참조의 범위가 끝날 때까지 수명을 연장합니다.
<code class="cpp">std::string s1 = getString(); // s1 is initialized with a copy of the temporary auto& s2 = getString(); // s2 binds to the temporary by reference</code>
또는 임시가 삭제되기 전에 기본 문자 배열에 대한 포인터를 사용할 수 있습니다.
<code class="cpp">std::cout << getString().c_str() << std::endl; // Temporary is destroyed after the expression completes</code>
위 내용은 ## 반환된 문자열에 대해 `std::string.c_str()`을 호출하면 정의되지 않은 동작이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!