float问题
#include <stdio.h>#include <stdlib.h>
int main()
{
{
float a;
a = 23.14;
printf("%f",a);
}
system("PAUSE");
return 0;
}
为什么结果23.139999
后来
#include <stdio.h>
#include <stdlib.h>
int main()
{
{
double a;
a = 23.14;
printf("%d",a);
}
system("PAUSE");
return 0;
}
数字越来越怪 171798692 {:10_266:} 小数点都不带 还有%11.9f的11貌似没用 怎么改都行 第一个问题
%f:不指定宽度,整数部分全部输出并输出6位小数。
第二个问题
用%d格式化浮点,和浮点数的存储结构有关系,你可以查一下单进度float存储格式,printf在进行参数入栈时是根据实参的类型进行入栈,而不是根据格式化字符中指定的类型,,内存中会以整数格式存储浮点,你可以反汇编一下,就知道了
第三个问题
%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。
%.x f x表示显示几个小数位 如果不写 默认小数点后无数字
% d是输入输出整型我记得
页:
[1]