인프런 커뮤니티 질문&답변

김서현님의 프로필 이미지
김서현

작성한 질문수

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

3.5 정수와 실수

unsigned가 없는 float에 부호가 0인 이유

해결된 질문

작성

·

494

1

16:50을 보면 실수에는 unsigned가 없기 때문에 무조건 부호 비트가 들어간다는 설명이 있습니다. unsigned가 양수를 나타내는 것, signed가 음수를 나타내는 것으로 알고 있습니다. 그렇다면 음수인 1이 부호비트에 들어가야 하는 것 아닌가요?

부호비트에 0이 들어가는 건

1. 2의 보수법 표현 때문

  1. 아니면 unsigned int에 대한 자료형이 없을 뿐 unsigned int에 대해 저런 식으로 표기하기 때문

     

    1,2 중 어떤 case인지, 아님 기타의 case 때문인지 궁금합니다.

답변 1

2

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

 

말씀해주신 부호 비트에 0 이 들어가는 것은, 해당 강의 16:50 부분에서 float 자료형의 변수 a 에 할당된 1.234f 값에 대한 표현 방식 예시이기 때문입니다. 즉, 예시에 사용된 float 형태의 값 1.234f양수 이므로, 부호비트가 0 인 것입니다.

 

또한, "unsigned 가 양수를 나타내는 것, signed 가 음수를 나타내는것" 의 표현은 올바르지 않습니다.

  • unsigned : 음수 값을 표현할 수 없는 자료형입니다.

  • signed : 양수와 음수 모두를 표현할 수 있는 자료형입니다. 최상위 비트는 부호 비트로 사용됩니다.

 

float 자료형에서는 실수를 표현하는 IEEE 754 표준에 따른 규칙을 사용하며,
부호 비트의 값이 0 일 경우 양수, 1 일 경우 음수를 나타냅니다.

 


김서현님의 프로필 이미지
김서현

작성한 질문수

질문하기