inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

0.10 이진수

0.10 17:00 경 8비트 정수의 범위에 대한 질문

해결된 질문

434

김민수

작성한 질문수 19

2

안녕하세요, 강의를 잘보고 잘 이해하고 있다고 생각하고 진행하고 있습니다만, 의문점이 생겼습니다.

8비트 정수의 범위를 설명해주실 때

부호가 있는(signed) 정수일 경우 범위를 -128 ~ 127로

표현해주셨는데요.

분명 128의 숫자는 2진수로 표현하였을 때 1000 0000이 맞습니다.

이걸 알려주신 '2의 보수' 표현법으로 -128을 나타내면

1000 0000 -> 0111 1111 이 되고 +1을 하면

1000 0000가 됩니다만 앞선 설명에서는 첫번째 비트공간을

음수,양수를 판별하기 위해 사용되는 자리라고 설명해주셔서

그렇게 생각하고 있었습니다만 이렇게 될 경우

8비트 이니까 128의 2진수인 1000 0000에서 맨앞에 1이 부호를 표현하는 자리이기 때문에 짤리고 000 0000 으로 표현되는 것 이 아닌가요?

그렇게 되면 "부호가 있는 정수"의 범위일 경우

000 0000 ~ 111 1111(127)이 된다는 건데 뭔가 이상하고

그렇다고 1000 0000 을 -0으로 치부해 버리면

0을 '2의 보수' 계산법을 통해 계산하였을 경우 똑같이

-0 이나 0이나 같은 0000 0000 값이 나와서 이상하고

그냥 -128의 경우 +128이나 -128이나 2진수가 같기 때문에 이럴경우는 1000 0000 일때 000 0000 이여도 -128로 정해둔 것 인가요? 아니면 다른 이유가 있을까요?

c

답변 1

1

강민철

안녕하세요

예리한 지적이시네요^^

말씀해주신 이유로 인해 -n과 n은 동시에 이진수로 표현할 수 없습니다.

이는 2의 보수법의 한계이지요.

 

그렇기 때문에 n 비트로 표현 가능한 수의 범위 자체가

-2^n~2^n이 아니라

-2^n~2^n-1 인 것입니다.

Export template 안됨

1

65

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

93

3

main 함수에서 왜 int만 선언이 되는걸까요

1

82

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

81

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

80

1

프로토타입과 함수간의 인자 불일치

1

87

2

12.12 헤더 관련 질문

1

74

2

Visual Studio Community 2026 사용 문의

1

171

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

73

2

getchar(), putchar()

1

111

3

강의자리ㅛ

1

93

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

129

2

소스파일안에 여러 파일

1

87

2

F5와 F7의 차이

1

91

2

c = TWO * (a+b); 에서 a와 b는?

1

67

2

; 세미콜론을 붙이는 기준에 문의

1

78

1

Step over 기능 문의

1

65

2

2.6 강의 따옴표 출력 규칙 문의

1

87

2

int main 함수 관련 오류 문의

1

77

2

13.4 words[0]

0

73

2

11.7 함수를 구현해 봤습니다.

1

67

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

71

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

61

2

11.6 fit_str함수를 구현해 봤습니다.

1

59

2