장장 곱셈 오버플로
다음 코드를 고려하세요.
long long int n = 2000*2000*2000*2000; // overflow
이 코드에서 오버플로가 발생하는 이유는 무엇인가요? 정수 리터럴 상수를 곱하고 그 결과를 long long에 할당할 때 변수?
다음과 비교하면 작동합니다.
long long int n = pow(2000,4); // works long long int n = 16000000000000; // works
C의 정수 리터럴은 해당 값에 따라 달라지는 기본 유형을 갖습니다. 이 경우 2000은 일반적으로 32비트 유형인 int 변수에 들어갈 수 있습니다.
산술 연산은 더 큰 유형의 피연산자를 사용하여 수행되지만 int보다 작지는 않습니다. 따라서 첫 번째 경우에는 int*int로 곱셈이 수행되어 int 결과가 나옵니다.
int 결과가 오버플로될 수 있으므로 문제가 발생하는데 코드에서는 이를 long long 변수에 저장하려고 합니다. . C는 대상을 기반으로 유형을 추론하지 않으므로 할당으로 인해 오버플로가 방지되지 않습니다.
이 문제를 방지하려면 정수 리터럴을 곱하기 전에 명시적으로 long long으로 캐스팅할 수 있습니다.
long long int n = (long long int)2000*2000*2000*2000;
위 내용은 `long long` 변수에 할당할 때에도 정수 리터럴 상수 곱셈이 오버플로되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!