C의 문자열 리터럴 및 부울 오버로드 해결
C에서 오버로드된 메서드를 사용하면 이름은 같지만 매개변수가 다른 여러 메서드를 정의할 수 있습니다. 유형. 그러나 실행할 정확한 오버로드를 찾는 것이 때때로 예상치 못한 것처럼 보일 수 있습니다. 특정 경우에 문자열 리터럴이 std::string 오버로드 대신 bool 오버로드와 일치하는 이유를 살펴보겠습니다.
다음 코드를 고려하세요.
<code class="cpp">class Output { public: static void Print(bool value) { std::cout << value ? "True" : "False"; } static void Print(std::string value) { std::cout << value; } }; Output::Print("Hello World");</code>
Output::Print를 호출할 때 "Hello World", 문자열 리터럴을 인쇄할 것으로 예상할 수 있습니다. 그러나 놀랍게도 True가 인쇄됩니다. 이는 내부적으로 발생하는 암시적 변환으로 인해 발생합니다.
C에서 "Hello World"와 같은 문자열 리터럴의 유형은 "12개의 const 문자 배열"입니다. 이는 암시적으로 "const char에 대한 포인터"로 변환될 수 있으며, 이는 암시적으로 bool로 변환될 수 있습니다. 이 표준 변환 순서는 문자열 리터럴을 std::string으로 변환하는 사용자 정의 변환 순서보다 선호됩니다.
C 표준(13.3.3.2/2)에 따라 표준 변환 순서가 더 높게 지정됩니다. 오버로드 해결 중 사용자 정의 변환 시퀀스보다 우선순위가 높습니다. 문자열 리터럴에서 bool로의 변환은 표준 변환이므로 std::string 변환보다 우선하며 Print(bool) 오버로드가 선택됩니다.
std::string 오버로드가 호출되면 std::string 값을 명시적으로 제공합니다.
<code class="cpp">Output::Print(std::string("Hello World"));</code>
혼란을 피하고 의도한 오버로드가 실행되도록 하려면 C에서 이러한 암시적 변환 및 오버로드 해결 규칙을 이해하는 것이 중요합니다.
위 내용은 C에서 문자열 리터럴이 `std::string` 오버로드 대신 `bool` 오버로드를 호출하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!