최음수 정수를 사용한 함수 오버로딩의 모호성
C에서 함수 오버로딩은 이름은 같지만 매개변수 목록이 다른 여러 함수를 허용합니다. 그러나 가장 큰 음의 정수 값이 발생하면 암시적 유형 변환으로 인해 모호성 오류가 발생할 수 있습니다.
문제 이해
다음 코드 조각은 문제를 보여줍니다.
<code class="cpp">void display(int a) { cout << "int" << endl; } void display(unsigned a) { cout << "unsigned" << endl; } int main() { int i = -2147483648; cout << i << endl; // prints -2147483648 display(-2147483648); // error: ambiguous function call }
가장 음의 정수(-2147483648)가 디스플레이(-2147483648)에 전달되면 컴파일러는 "모호한 함수 오버로드" 오류를 생성합니다. 이는 컴파일러가 호출할 함수(display(int) 또는 display(unsigned))를 결정할 수 없기 때문에 발생합니다.
정수 리터럴의 역할
주어진 예는 C에 음의 정수 리터럴이 없기 때문에 발생합니다. 정수 리터럴은 0이 아닌 숫자로 시작해야 합니다. -2147483648의 경우 음수 기호는 단항 빼기 연산자로 해석되어 -1 *(2147483648) 표현식이 됩니다.
Type Promotion
이후 2147483648이 int의 범위를 초과하면 long int로 승격됩니다. 그러나 이번 프로모션은 매개변수 유형인 디스플레이(int)와 디스플레이(unsigned) 사이에 모호성을 만들어 오류를 발생시킵니다.
포터블 솔루션
이식 가능한 방식으로 유형에 대한 최소값 또는 최대값을 사용할 수 있습니다.
<code class="cpp">std::numeric_limits<type>::min(); // or max()</code>
이 방법을 활용하면 모호한 함수 오버로드가 방지되어 구현에 관계없이 올바른 유형 처리가 보장됩니다.
위 내용은 C에서 가장 음의 정수를 사용하면 함수 오버로딩이 모호해지는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!