대부분 음의 정수에 대한 오버로드 해결의 모호함
C에서 함수 오버로드를 사용하면 여러 함수가 이름은 같지만 매개변수 유형이 다를 수 있습니다. 그러나 오버로드된 함수 호출을 해결할 때 컴파일러가 호출하기에 가장 적합한 함수를 결정할 수 없으면 모호성이 발생할 수 있습니다.
정수 및 부호 없는 정수 값을 표시하기 위한 함수 오버로드를 보여주는 다음 코드를 고려하세요.
<code class="cpp">void display(int a) { cout << "int" << endl; } void display(unsigned a) { cout << "unsigned" << endl; }
우리가 이해한 바에 따르면, int에 대해 지정된 범위 내의 모든 정수 값은 display(int)를 호출해야 하지만 이 범위 밖의 값은 모호성을 유발합니다. 그러나 표시할 가장 음수인 int 값(-2147483648)을 전달하려고 시도하면 컴파일러에서 오류가 발생합니다.
call of overloaded display(long int) is ambiguous
이 놀라운 동작은 C에 음수 리터럴이 없기 때문에 발생합니다. C 표준에 정의된 정수 리터럴에는 '-' 문자가 포함되지 않습니다. 대신, 뒤에 숫자가 오는 '-'가 나타나면 컴파일러는 이를 양의 정수 리터럴에 적용된 단항 부정 연산자로 처리합니다.
우리의 경우 '-2147483648'은 '-1 * 2147483648'. '2147483648'은 int의 범위를 초과하므로 long int로 승격됩니다. 이제 display(int) 및 display(long int) 모두 함수 호출에 대한 실행 가능한 후보이기 때문에 이 유형 승격은 모호성을 초래합니다.
이러한 모호성을 방지하려면 std::numeric_limits 클래스를 사용하여 다음을 수행하는 것이 좋습니다. 이식 가능한 방식으로 다양한 데이터 유형의 최소값 또는 최대값을 검색합니다.
<code class="cpp">std::cout << std::numeric_limits<int>::min() << endl;</code>
위 내용은 오버로드된 함수에 가장 음의 정수를 전달하면 C에서 모호함이 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!