백엔드 개발 C#.Net 튜토리얼 C 언어에서 데이터 int의 값 범위는 무엇입니까?

C 언어에서 데이터 int의 값 범위는 무엇입니까?

Jun 30, 2020 am 11:17 AM
c 언어 int

C++에서는 int가 4바이트, 32비트를 차지하고 데이터 범위는 -2147483648~2147483647[-2^31~2^31-1]입니다. int형 데이터는 부호 있는 정수 데이터이고, 가장 높은 비트는 부호 비트(0은 양수, 1은 음수)이다.

C 언어에서 데이터 int의 값 범위는 무엇입니까?

C++에서는 int가 4바이트, 32비트를 차지하고 데이터 범위는 -2147483648~2147483647[-2^31~2^31-1]입니다.

2바이트를 예로 들어 설명하는 자세한 답변 프로세스:

C에서 int 유형 데이터는 부호 있는 정수 데이터이고 가장 높은 비트는 부호 비트입니다(0은 양수, 1은 음수를 의미).

1바이트는 8개의 이진수 비트와 같습니다. 많은 컴퓨터 시스템에서 2의 보수는 일반적으로 부호 있는 숫자를 나타내는 데 사용됩니다(상보 시스템).

원래 코드: 가장 높은 비트는 부호 비트(0은 양수, 1은 음수)이고, 다른 비트는 일반적인 방식으로 숫자의 절대값을 나타냅니다.

역코드: 서명된 책의 경우 양수의 역코드는 원본 코드와 동일하며 음수의 역코드는 부호 비트를 제외한 원본 코드의 모든 비트를 비트 단위로 반전한 것입니다.

보완 코드: 양수의 보수 코드는 원래 코드와 동일하며, 음수의 보수 코드는 최하위 비트에 1이 추가된 역코드입니다.

2바이트이므로 최대 바이너리 원본 코드는 0111 1111 1111 1111 = 2^15 - 1 = 32767입니다.

최소값은 1111 1111 1111 1111 = - (2^15 - 1) = -32767입니다.

원본 코드에서 0의 표현은 양수와 음수로 구분됩니다. [+0] 원본 = 0000 0000 0000 0000 [-0] 원본 =1000 0000 0000 0000.

그래서 바이너리 원본 코드로 표현하면 범위는 -32767~-0, 0~32767이 됩니다. 0이 2개 있으므로 서로 다른 값의 개수는 2^16-1이 됩니다.

컴퓨터가 보수 코드를 사용하여 데이터를 저장할 때 0의 표현은 고유합니다: [+0] 보수 = [-0] 보수 = 0000 0000 0000 0000

이때 양수 인코딩은 0000 0000부터 변경되지 않습니다. 0000 0000 ~ 0111 1111 1111 1111은 여전히 ​​0 ~ 32767을 나타냅니다.

음수는 보수 규칙을 따라야 합니다. 즉, -32767의 보수는 1000 0000 0000 0001입니다.

그래서 보완코드에는 원래 코드보다 코드가 하나 더 많아지게 됩니다. 이 코드는 1000 0000 0000 0000입니다. 어떤 원본 코드도 보완코드로 변환하면 1000 0000 0000 0000이 되는 것은 불가능하기 때문에 사람들이 규정하는 것입니다. 1000 0000 0000 0000의 2의 보수 인코딩은 -32768입니다.

결론: int형 데이터가 2바이트를 차지하면 2^16개의 변화를 나타낼 수 있습니다. 가장 높은 비트가 부호 비트이므로 0도 한 유형을 차지하므로 양수와 음수에서 2^15개의 변화가 있으므로 양수와 음수 최대값은 대칭이 아니다. 즉, int형 데이터의 값 범위는 -32768 ~ 32767이다.

C 언어에서 데이터 int의 값 범위는 무엇입니까?

확장 정보:

int 사용 방법:

정의 방법:

int i;//정수 변수 i 정의

int i=1;//정수 변수 i를 정의하고 다음으로 초기화합니다. 1

상수 정의:

const int i;//상수에 초기 값을 지정해야 하기 때문에 컴파일 오류가 발생했습니다.

const int i=1;//값이 1인 상수 i를 정의합니다.

Java에서 상수를 정의합니다.

final int i=1;//상수 i 정의, 값은 1

권장 튜토리얼: "C Language"

위 내용은 C 언어에서 데이터 int의 값 범위는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어에서 typedef 구조체 사용법 C 언어에서 typedef 구조체 사용법 May 09, 2024 am 10:15 AM

typedef struct는 C 언어에서 구조 사용을 단순화하기 위해 구조 유형 별칭을 만드는 데 사용됩니다. 구조 별칭을 지정하여 기존 구조에 새 데이터 유형의 별칭을 지정합니다. 향상된 가독성, 코드 재사용 및 유형 확인 등의 이점이 있습니다. 참고: 별칭을 사용하기 전에 구조를 정의해야 합니다. 별칭은 프로그램에서 고유해야 하며 선언된 범위 내에서만 유효해야 합니다.

C 언어에서 strcpy와 strcat의 차이점 C 언어에서 strcpy와 strcat의 차이점 May 08, 2024 pm 01:03 PM

strcpy는 문자열을 다른 문자열에 복사하고, strcat는 문자열을 다른 문자열에 추가합니다. 주요 차이점은 다양한 목적, 다양한 dst 매개변수 처리 및 다양한 보안 고려사항을 포함합니다.

C 언어에서 Real은 무엇을 의미합니까? C 언어에서 Real은 무엇을 의미합니까? May 09, 2024 pm 12:06 PM

real은 C 언어에서 배정밀도 부동 소수점 숫자를 나타내는 데 사용되는 데이터 유형입니다. 8바이트를 차지하고 소수점 이하 약 15자리의 정밀도를 가지며 범위는 [-1.7976931348623157e+308, 1.7976931348623157e+308]입니다.

C 언어에서 scanf 오류가 발생하면 어떻게 해야 할까요? C 언어에서 scanf 오류가 발생하면 어떻게 해야 할까요? May 09, 2024 am 11:39 AM

C 언어에서 scanf 함수 오류를 처리하는 방법은 다음과 같습니다. 1. 형식 문자열을 확인합니다. 3. 반환 값을 확인합니다. 4. 오류 처리 기능을 사용합니다. 사용자 정의 오류가 처리됩니다. 오류를 방지하려면 올바른 데이터 유형을 사용하고, 입력의 유효성을 주의 깊게 확인하고, 반환 값을 확인하고, 프로그램의 잠재적인 오류를 처리하십시오.

C 언어로 거듭제곱 함수를 구현하는 방법 C 언어로 거듭제곱 함수를 구현하는 방법 May 09, 2024 pm 11:33 PM

C 언어에는 지수 연산을 구현하는 두 가지 방법이 있습니다. pow() 함수를 사용하여 첫 번째 매개변수의 두 번째 매개변수의 거듭제곱을 계산합니다. 재귀적으로 또는 반복적으로 구현할 수 있는 사용자 정의 검정력 함수를 정의합니다. 재귀적 방법은 검정력이 0이 될 때까지 계속해서 두 배로 증가합니다. 반복 방법은 루프를 사용하여 밑수를 하나씩 곱합니다.

_C 언어의 복잡한 사용법 _C 언어의 복잡한 사용법 May 08, 2024 pm 01:27 PM

복소수 유형은 C 언어에서 실수부와 허수부를 포함하는 복소수를 나타내는 데 사용됩니다. 초기화 형태는 complex_number = 3.14 + 2.71i 이며 실수부분은 creal(complex_number)를 통해, 허수부분은 cimag(complex_number)를 통해 접근할 수 있습니다. 이 유형은 덧셈, 뺄셈, 곱셈, 나눗셈 및 모듈로와 같은 일반적인 수학 연산을 지원합니다. 또한 cpow, csqrt, cexp 및 csin과 같은 복소수 작업을 위한 함수 세트가 제공됩니다.

C 언어에서 제한을 사용하는 방법 C 언어에서 제한을 사용하는 방법 May 08, 2024 pm 01:30 PM

제한 키워드는 포인터를 통해서만 변수에 액세스할 수 있음을 컴파일러에 알리고 정의되지 않은 동작을 방지하고 코드를 최적화하며 가독성을 향상시키는 데 사용됩니다. 여러 포인터가 동일한 변수를 가리킬 때 정의되지 않은 동작을 방지합니다. 코드를 최적화하기 위해 컴파일러는 제한 키워드를 사용하여 변수 액세스를 최적화합니다. 포인터를 통해서만 변수에 액세스할 수 있음을 표시하여 코드 가독성을 향상시킵니다.

_C언어에서 bool은 무슨 뜻인가요? _C언어에서 bool은 무슨 뜻인가요? May 08, 2024 pm 01:33 PM

_Bool은 C 언어에서 true 또는 false 두 가지 값만 포함하는 간단한 데이터 유형입니다. 조건이나 논리식의 결과를 나타내는 데 사용되며 일반적으로 1바이트의 메모리를 차지하며 true 또는 false만 저장할 수 있습니다. 거짓. 거짓 값.

See all articles