부호 있는/부호 없는 정수 오버플로의 예기치 않은 결과
C에서 정수 오버플로는 데이터 유형의 부호 있는 여부에 따라 예기치 않은 결과를 초래할 수 있습니다. .
다음 사항을 고려하세요. 프로그램:
#include <iostream> int main() { int x(0); std::cout << x << std::endl; x = x + 2147483647; std::cout << x << std::endl; x = x + 1; std::cout << x << std::endl; std::cout << std::endl; unsigned int y(0); std::cout << y << std::endl; y = y + 4294967295; std::cout << y << std::endl; y = y + 1; std::cout << y << std::endl; }
이 프로그램의 출력은 여러분을 놀라게 할 수 있습니다:
0 2147483647 -2147483648 0 4294967295 0
설명
부호 있는 정수의 경우, 오버플로 동작이 정의되지 않았습니다. 대부분의 구현에서는 2의 보수가 사용되며 이로 인해 예기치 않은 래핑 동작이 발생합니다. 예를 들어 위 프로그램에서는
부호 없는 정수의 경우 오버플로는 잘 정의되어 있으며 모듈로 2비트를 둘러쌉니다. 즉, 최대값을 넘으면 값이 0으로 재설정됩니다. 이는 y의 출력에 대해 설명합니다. 여기서 y는 부호 없는 최대 값인 4294967295를 오버플로한 후 0으로 돌아갑니다.
부호 있는 정수 오버플로의 동작은 언어에 따라 보장되지 않으며 언어에 따라 다를 수 있다는 점에 유의하는 것이 중요합니다. 구현 및 기계 아키텍처. 따라서 일반적으로 프로그램에서 이러한 동작에 의존하는 것은 권장되지 않습니다.
위 내용은 C에서 정수 오버플로로 인해 부호 있는 정수와 부호 없는 정수에 대해 다른 결과가 나타나는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!