>백엔드 개발 >C++ >C에서 문자열 리터럴이 `std::string` 오버로드 대신 `bool` 오버로드를 호출하는 이유는 무엇입니까?

C에서 문자열 리터럴이 `std::string` 오버로드 대신 `bool` 오버로드를 호출하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-04 10:12:01860검색

Why does a string literal call a `bool` overload instead of a `std::string` overload in C  ?

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

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