일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 원격 제어 프로그램
- 유튜브 동영상 강의
- 충남 천안
- 캡슐화
- 표준 입출력
- 언제나 휴일
- 추천
- 실습으로 다지는 c#
- 프로젝트
- 파이썬
- 소스 코드
- c#
- 알고리즘
- Windows Forms
- 소켓 통신
- 독립기념관
- 네트워크 프로그래밍
- c언어
- C++
- 산책하기 좋은 곳
- 강의
- 언제나휴일
- 표준 라이브러리 함수
- 클래스 다이어그램
- 실습
- 동영상 강의
- 무료 동영상 강의
- 동영상
- 졸업 작품 소재
- 안드로이드 앱 개발
- Today
- Total
프로그래밍 언어 및 기술 [언제나휴일]
실수 형식 표현 범위, FLT_MIN, FLT_MAX, FLT_TRUE_MIN 본문
안녕하세요. 언제나 휴일에 언휴예요.
이번 글은 강의는 아닙니다.
이 내용을 모르더라도 C언어를 익히는 데 영향이 없습니다.
실수 형식의 메모리 구조
C언어에서 실수는 메모리에 2진 체계에 의해 부호부, 지수부, 가수부로 표현합니다.
double 형식은 부호부(1), 지수부(11), 가수부(52)로 구성합니다.
float 형식은 부호부(1), 지수부(8), 가수부(23)로 구성합니다.
실수를 메모리에 표현하는 방법은 별도의 게시글로 제공하고 있으니 참고하세요.
FLT_MIN, FLT_MAX
실수 형식의 양수는 FLT_MIN~FLT_MAX까지 표현 가능한 것으로 알고 있습니다.
float.h에 이 값을 약속하고 있죠.
그런데 이러한 값이 메모리에 어떻게 표현하는지 아시나요?
FLT_MIN은 지수부가 1, 가수부가 1입니다. 부호는 양수이므로 0이죠.
FLT_MAX는 지수부가 0xFE, 가수부가 0x7FFFFF입니다.
그렇다면 지수부가 0인 값들과 0xFF인 값들은 무엇일까요?
지수부가 0xFF이고 가수부가 0인 값을 무한대로 정의하고 있습니다.
그리고 지수부가 0xFF이고 가수부가 0이 아닌 모든 값은 수가 아닌 값으로 nan으로 정의하고 있어요.
이에 유효한 지수부를 0x01~0xFE라고 약속한 것이죠.
하지만 지금은 지수부가 0이고 가수부가 1인 값을 FLT_TRUE_MIN으로 약속하고 있으며 실제 표현이 가능한 수입니다.
이 값들이 얼마인지는 다음 코드를 실행하면 당연히 알 수 있겠죠.
이를 확인하는 소스 코드를 같이 올립니다.
다시 한 번 얘기하지만 이 부분은 C언어 강의가 아닙니다.
/* https://ehpub.co.kr 언제나 C언어 실수 형식 표현 범위 */
#include //표준 입출력 헤더
#include
typedef union {
float value;
struct {
unsigned mantissa : 23;
unsigned exponent : 8;
unsigned sign : 1;
}sv;
}Test;
int main(void)
{
Test test = { 0 };
test.sv.exponent = 1;
test.sv.mantissa = 1;
printf("%.50f\n", test.value);
printf("%.50f\n", FLT_MIN);
test.sv.exponent = 0;
printf("%.50f\n", test.value);
printf("%.50f\n", FLT_TRUE_MIN);
test.sv.exponent = 0xFE;
test.sv.mantissa = 0x7FFFFF;
printf("%.50f\n", test.value);
printf("%.50f\n", FLT_MAX);
test.sv.exponent = 0xFF;
test.sv.mantissa = 0;
printf("%.50f\n", test.value);
test.sv.mantissa = 3;
printf("%.50f\n", test.value);
return 0;
}
실행 결과입니다.
0.00000000000000000000000000000000000001175494490952
0.00000000000000000000000000000000000001175494350822
0.00000000000000000000000000000000000000000000140130
0.00000000000000000000000000000000000000000000140130
340282346638528859811704183484516925440.00000000000000000000000000000000000000000000000000
340282346638528859811704183484516925440.00000000000000000000000000000000000000000000000000
inf
nan
언제나휴일 추천 여행 및 산책
'C & C++ > 언제나 C언어' 카테고리의 다른 글
비교 연산, 논리 연산의 도움을 받으세요. (1) | 2025.01.03 |
---|---|
논리 형식과 논리 연산 (0) | 2025.01.03 |
이럴 때 나머지 연산을 사용하자. 0123401234012… (0) | 2025.01.03 |
산술 연산과 overflow (0) | 2025.01.03 |
실수 형식 double, float 표현과 출력 (0) | 2025.01.03 |
확장 문자 형식 wchar_t와 한글 문자 (0) | 2025.01.03 |
문자 형식 char와 ASCII 코드 (1) | 2025.01.03 |
정수 형식과 표현 범위 (char, short, int, long,…) (0) | 2025.01.03 |