"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > C++에서 'long'은 최소 32비트를 보장하나요?

C++에서 'long'은 최소 32비트를 보장하나요?

2024-11-07에 게시됨
검색:329

Is `long` Guaranteed to Have at Least 32 Bits in C  ?

long이 32비트를 갖도록 보장됩니까?

C 표준을 기반으로 한 일반적인 가정에도 불구하고 long이 32비트를 갖도록 보장되는지 여부에 대한 의문이 생깁니다. 최소 32비트. 표준은 기본 적분 유형을 다음과 같이 분류합니다:

sizeof(char) ≤ sizeof(short int) ≤ sizeof(int) ≤ sizeof(long int)

그러나 많은 사람들은 이를 기반으로 가정합니다. 계층구조, long은 32비트를 가져야 합니다. 그러나 표준에서는 바이트의 비트 수가 구현에 따라 정의된다고 명시적으로 명시합니다.

Alf P. Steinbach의 주장

이 모순처럼 보이는데도 불구하고 Alf P. Steinbach는 long이 32비트임을 보장한다고 주장했습니다. 그는 이 주장을 long이 보유할 수 있는 값 범위(LONG_MIN ~ LONG_MAX)에 대한 암시적 제한에 기반을 두고 있습니다.

C 표준은 다음을 정의하는 C 표준(18.3.2)을 참조합니다. ]LONG_MIN ≤ -2^31 1 LONG_MAX ≥ 2^31 - 1

LONG_MIN ≤ -2^31   1
LONG_MAX ≥ 2^31 - 1
32비트 표현에 대한 연결

이는 긴 범위를 설정하지만 명시적으로 32비트를 보장하지는 않습니다. 그러나 두 가지 가능성이 있습니다.

    2진수 표현:
  1. 음수가 2진수로 표현되는 경우 LONG_MIN 또는 LONG_MAX를 저장하려면 32비트가 필요합니다.
  2. 명시적 부호 비트:
  3. 부호 비트가 음수에 사용되는 경우에도 총 저장 공간에는 여전히 32비트가 필요합니다.
결론

C 표준에서는 32비트를 갖기 위해 명시적으로 long을 요구하지 않지만 최소 범위 요구 사항(LONG_MIN ~ LONG_MAX)은 암시적으로 이를 필요로 합니다. 이는 이러한 값을 표현하려면 32비트의 저장 공간이나 동등한 값 용량을 갖춘 구현별 메커니즘이 필요하기 때문입니다. 따라서 C에서는 long이 최소 32비트를 갖는다고 보장한다고 결론 내릴 수 있습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3