>백엔드 개발 >C++ >임시 `std::string` 개체의 `c_str()`에 액세스하는 것이 안전합니까?

임시 `std::string` 개체의 `c_str()`에 액세스하는 것이 안전합니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-06 19:10:03279검색

Is It Safe to Access the `c_str()` of a Temporary `std::string` Object?

임시 문자열의 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.