임시 문자열과 함께 std::string::c_str()을 사용할 때 발생할 수 있는 위험
다음 C 코드 조각을 고려하세요.
void consumer(char const* p) { std::printf("%s", p); } std::string random_string_generator(); consumer(random_string_generator().c_str());
이 코드는 C 표준에 따라 올바른 형식인지 의문을 제기합니다.
random_string_generator()가 임시 std::string 객체를 반환한다는 사실에서 우려가 나옵니다. 그런 다음 c_str() 포인터를 사용하여 잠재적으로 포인터가 사용되기 전에 임시 std::string 개체가 파괴되기 쉬운 상태로 남습니다.
의미를 이해하려면 C에서 임시 개체의 수명을 조사해야 합니다.
C 표준에 따르면 임시의 수명은 해당 임시가 생성된 전체 표현이 끝날 때까지 연장됩니다. 이 경우 전체 표현은 소비자에 대한 호출입니다. 따라서 임시 std::string 개체는 소비자 함수의 실행이 완료될 때까지 삭제되지 않습니다.
따라서 우리가 얻은 c_str() 포인터는 소비자 호출 전체에서 유효하게 유지되어 코드를 잘 만들 수 있습니다. -형성되어 사용하기에 안전합니다.
이 보증은 전체 표현의 수명 동안만 유효하다는 점에 유의하는 것이 중요합니다. c_str() 포인터가 이 컨텍스트 외부에서 저장되고 사용되는 경우 임시 std::string 객체가 이미 파괴되었을 수 있으므로 동작이 정의되지 않습니다.
위 내용은 C에서 임시 문자열과 함께 `std::string::c_str()`을 사용하는 것이 안전합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!