Double 부동소수점수를 f형식변환자를 이용하여 printf() 할때 출력에 문제가 없는 이유가 궁금합니다
447
작성한 질문수 1
Double 형식으로 저장된 데이터는 8byte 입니다.
Printf() 함수에서 float수는 변수 스택에 들어갈때 8byte를 할당하고 출력시 8byte를 사용하므로 데이터스택의 호출크기가 다름으로 생기는 오류는 없을거 같습니다.
하지만 double 형식 데이터를 데이터스택에 저장하는 과정에서 %f를 의식하여 8byte를 할당 했다고 하더라도 float 와 double은 메모리 구조가 다른데 어떻게 해석해 낼 수 있는지 궁금합니다.
혹시 printf() 함수는 데이터 스택에 float를 저장하는 과정에서 저장할 데이터가 float인지 데이터의 크기를 통해 확인하여 단순히 데이터크기만 8byte로 늘려주는게 아니라 데이터구조(=부호,지수,fraction에 할당하는 bit수)를 double의 형식으로 변환하여 저장하고 출력할땐 %f %d 모두 double부동소수점 수의 데이터구조를 기준으로 출력하는건가요?
Printf()함수의 데이터스택에 데이터가 저장되는 과정에서 함수의 문자열 속 형식지정자들이 데이터에 할당되는 데이터의 크기에 영향을 미치는 것인지, 컴파일러가 데이터의 크기와 형태만 보고 할당하는 것인지 궁금합니다. 혹시 디버깅을 통해 확인이 가능할까요?
답변 1
1
printf는 내부적으로 float나 double이나
모두 double과 동일하게 취급합니다.
float로 인자를 준다고 해도 해당 인자는 double로 승격됩니다.
이해에 도움이 될 만한 링크를 첨부합니다. 참고하시면 도움이 될 듯 합니다.
https://stackoverflow.com/questions/28097564/why-does-printf-promote-a-float-to-a-double
https://stackoverflow.com/questions/4264127/correct-format-specifier-for-double-in-printf
Export template 안됨
1
65
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
98
3
main 함수에서 왜 int만 선언이 되는걸까요
1
85
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
82
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
81
1
프로토타입과 함수간의 인자 불일치
1
87
2
12.12 헤더 관련 질문
1
74
2
Visual Studio Community 2026 사용 문의
1
172
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
73
2
getchar(), putchar()
1
112
3
강의자리ㅛ
1
93
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
131
2
소스파일안에 여러 파일
1
89
2
F5와 F7의 차이
1
93
2
c = TWO * (a+b); 에서 a와 b는?
1
69
2
; 세미콜론을 붙이는 기준에 문의
1
78
1
Step over 기능 문의
1
66
2
2.6 강의 따옴표 출력 규칙 문의
1
88
2
int main 함수 관련 오류 문의
1
82
2
13.4 words[0]
0
73
2
11.7 함수를 구현해 봤습니다.
1
67
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
72
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
62
2
11.6 fit_str함수를 구현해 봤습니다.
1
60
2





