>백엔드 개발 >C++ >C에서 `(-2147483648 > 0)`이 True로 평가되는 이유는 무엇입니까?

C에서 `(-2147483648 > 0)`이 True로 평가되는 이유는 무엇입니까?

DDD
DDD원래의
2024-12-25 05:23:20221검색

Why Does `(-2147483648 > 0)` C에서 True로 평가 ?
0)` C에서 True로 평가됩니까? " />

C에서 (-2147483648 > 0)이 True를 반환하는 이유는 무엇입니까?

이 기사에서는 표현식 (-2147483648 >)이 있는 C의 당황스러운 동작을 살펴봅니다. ; 0) 예기치 않게 다음과 같이 평가됩니다. true.

-2147483648, 가장 작은 32비트 정수는 단항 - 연산자가 적용된 양수 값으로 표시됩니다. 그러나 long int 및 long long int가 int보다 더 큰 범위가 부족한 플랫폼에서는 이는 값이 정수 범위의 양수 쪽을 오버플로합니다.

결과적으로 컴파일러는 2147483648을 구현에 따른 것으로 처리합니다. 음수 값입니다. 단항 - 연산자를 적용한 후 양수 값이 되어 식이 true로 평가됩니다.

또는 구현 시 부호 없는 유형을 사용하여 값을 나타낼 수도 있으며 이 동작이 발생합니다. 는 C에서 정의되지 않았으며 구현은 적절하다고 생각되는 방식으로 오버플로를 자유롭게 해석할 수 있습니다.

이러한 예외를 방지하기 위해 INT_MIN과 같은 상수는 일반적으로 다음과 같이 정의됩니다. (-2147483647 - 1) -2147483648 대신 최소 정수 값을 올바르게 나타내는지 확인합니다.

위 내용은 C에서 `(-2147483648 > 0)`이 True로 평가되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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