>백엔드 개발 >C++ >C에서 임시 문자열과 함께 `std::string::c_str()`을 ​​사용하는 것이 안전합니까?

C에서 임시 문자열과 함께 `std::string::c_str()`을 ​​사용하는 것이 안전합니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-06 17:51:02967검색

Is it Safe to Use `std::string::c_str()` with Temporary Strings in C  ?

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

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