inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3.11 부동소수점형

부동소수점형

273

파이팅

작성한 질문수 26

2

3.11 부동소수점형 9:17에서 8비트 언사인드 정수는 0에서부터 255까지라고 하셨는데 왜 1부터 256이 아니라 0부터 255까지인건가요? 그리고 왜 124에서 127을 빼줘야 되는지 이해가 안가요 2^124-127 이부분이요

c

답변 1

1

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

먼저, 8 비트 unsigned 정수가 0 부터 255 까지인 이유는 다음과 같습니다.

8 비트 unsigned 정수의 경우, 각 비트는 0 또는 1 의 값을 가질 수 있습니다.

이 때, 8 개의 비트가 모두 0 일 경우, 이는 십진수로 0 을 의미합니다.

반면, 8 개의 비트가 모두 1 일 경우, 이는 다음과 같이 계산되어 255를 의미합니다.

2^7 + 2^6 + 2^5 + 2^4 + 2^3 + 2^2 + 2^1 + 2^0 = 255

따라서, 8 비트 unsigned 정수의 범위는 0 부터 255 까지입니다.

 

124 에서 127을 빼는 부분에 대한 설명은 다음과 같습니다.

32 비트 부동소수점의 경우, 지수부는 8 비트를 차지합니다.

이 때, 지수부의 값을 음수로 표현하기 위해서, 해당 지수부에 저장된 비트의 값에서 편향값 127 을 빼주는 것입니다.

예를 들어, 지수부가 124 라면 실제 지수 값은 124 - 127 = -3 입니다.

편향값을 사용하는 이유는, 부동소수점 수를 표현할 때, 양수 및 음수의 지수를 함께 표현할 수 있도록 하기 위함입니다.

2^(124 - 127) 부분에서, 실제 지수는 -3 이므로, 이 수는 2-3 승, 즉, 1 / 8 을 의미합니다.

Export template 안됨

1

18

2

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

1

54

3

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

1

56

2

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

1

54

2

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

1

49

1

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

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

137

2

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

1

61

2

getchar(), putchar()

1

93

3

강의자리ㅛ

1

79

2

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

1

113

2

소스파일안에 여러 파일

1

75

2

F5와 F7의 차이

1

76

2

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

1

58

2

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

1

69

1

Step over 기능 문의

1

53

2

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

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

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

1

62

2

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

1

65

2

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

1

53

2

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

1

53

2