임시 문자열의 c_str()에 액세스하는 것이 안전한가요?
C 프로그램에서 다음 코드는 우려를 불러일으킵니다.
void consumer(char const* p) { std::printf("%s", p); } std::string random_string_generator(); consumer(random_string_generator().c_str());
random_string_generator에 의해 생성된 임시 std::string 개체가 소비자를 호출하기 전에 파괴되어 잠재적으로 c_str() 포인터가 유효하지 않게 렌더링될 수 있다고 주장됩니다. 그러나 временной переменных 수명에 대한 표준 정의를 이해하는 것이 중요합니다.
C 표준에 따르면 std::string::c_str()에서 반환된 포인터는 const가 아닌 함수가 호출될 때까지 유효한 상태로 유지됩니다. std::string 객체에 있거나 파괴되었습니다. 주어진 코드에서 임시 std::string 객체는 소비자에 대한 호출을 포함하는 전체 표현식의 끝에서 소멸됩니다. 이는 코드의 형식이 올바른지 확인합니다.
소비자가 나중에 사용하기 위해 c_str() 포인터를 보존하려고 시도하지 않는 한 임시 std::string 객체는 유지되지 않을 것이라고 가정하는 것이 안전합니다. 조기에 파괴되었습니다. 임시 수명은 C 98부터 정확하게 정의되어 제시된 것과 같은 코드가 다양한 컴파일러에서 안전하게 실행되도록 보장합니다.
위 내용은 임시 `std::string` 개체의 `c_str()`에 액세스하는 것이 안전합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!