>백엔드 개발 >C++ >정수 리터럴을 곱하면 'long long' 변수에도 오버플로가 발생하는 이유는 무엇입니까?

정수 리터럴을 곱하면 'long long' 변수에도 오버플로가 발생하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-10 19:04:03913검색

Why Does Multiplying Integer Literals Result in Overflow Even with a `long long` Variable?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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