C 산술에서 Long Long Integer 오버플로 이해
다음 코드 조각을 고려하세요.
long long int n = 2000 * 2000 * 2000 * 2000; // overflow
이러한 이유는 무엇인가요? 코드를 저장하기 위한 long long 변수 선언에도 불구하고 오버플로가 발생합니다. 결과?
오버플로 이유
문제는 정수 리터럴 상수 2000의 유형에 있습니다. 기본적으로 정수 리터럴에는 해당 상수를 저장할 수 있는 가장 작은 유형이 할당됩니다. int보다 작지 않은 값. 2000은 32비트 int에 저장될 수 있으므로 이러한 리터럴에 대한 산술 연산은 int 연산으로 수행됩니다.
Type Promotion
n과 같은 long long 변수는 가능하지만 더 큰 값을 저장하면 곱셈 연산에 있는 유형 중 더 큰 유형으로 산술 연산자가 호출됩니다. 그러나 이 경우 대상 유형에 관계없이 더 큰 유형은 int로 유지됩니다.
오버플로에 대한 의미
즉, 곱셈의 결과는 2000 * 2000입니다. * 2000 * 2000은 32비트 정수로 계산되는데 결과가 int의 최대값을 초과하므로 오버플로됩니다. 보유할 수 있습니다.
대체 접근 방식
이 오버플로를 방지하려면 리터럴 상수에 대한 LL 접미사 또는 명시적 캐스트 연산자를 사용하여 정수 리터럴을 long long으로 명시적으로 캐스트할 수 있습니다. (long long):
long long int n = (long long)2000 * 2000 * 2000 * 2000; // no overflow
또는 pow 기능을 사용할 수도 있습니다. 결과를 계산하려면 긴 긴 값으로 계산이 수행되도록 해야 합니다.
long long int n = pow(2000, 4); // no overflow
pow 함수를 명시적으로 캐스팅하거나 사용하면 계산이 긴 긴 값으로 수행되어 오버플로를 방지할 수 있습니다.
위 내용은 정수 리터럴을 곱하면 'long long' 변수에도 오버플로가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!