inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

15.8 RGBA 색상 비트 마스크 연습문제

[(15. Bit Manipulation) - 8. RGBA 색상 비트 마스크 연습문제] Alpha의 값이 255일 때, float로 왜 1.0인가요?

해결된 질문

351

kynoh

작성한 질문수 7

0

강의 2분 50초부터 2분 55초 구간에
'float로 변환하면, 1.0이 될겁니다.'라고 하셨습니다.
 
각각의 color channel에 대한 data type은 unsigned char이므로, 8 bits의 size를 가지고 있습니다.
그러므로 만약 '255'라는 10진수를 저장한다면, binary data는 1111 1111 입니다.
 
그런데 이 binary data가, 어떻게 float type의 '1.0'을 의미하는 것인지 모르겠습니다.
 
32 bits size를 가지는 float type으로 casting하면, 0000 .... 1111 1111 (32bits) 이므로 '255.0'이 나옵니다.
 
혹시 8-bit 부동소수점 숫자로 표현한다는 것을 말씀하신것인가 싶어서, 1111 1111 라는 binary data를 8-bit 부동소수점 수로 직접 계산해보니 -1 * 16 * 1.9375 = -31이 나옵니다.
(Format : Sign 1 bit, Exponent 3 bits, Fraction 4 bits)
 
어떤 과정으로 인해서 alpha channel의 data인 '255', 즉 binary data 1111 1111 '1.0'이되는 것인가요?
 

c

답변 1

1

강민철

안녕하세요,

float형 255를 비트 단위로 따져본다면 한다면 질문자님의 말씀이 맞습니다만,

해당 부분을 말씀하시기 직전에 "255 분에 255, 다 찬 거죠" 라고 표현하신 것으로 봐서

해당 부분은 단순히 '255 중에서 255가 꽉 차 있는 상태', 즉 255/255를 표현하기 위해 그렇게 표현하신 것이 아닐까 싶습니다 :)

 

0

kynoh

다른 color channel들처럼, alpha의 binary data를  '표현된 숫자'와 연관지어서 생각하다보니 저런 의문이 생겼었습니다.

답변 감사드립니다!

:)

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