Q╜先森 发表于 2017-6-23 07:48:22

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:} 小数点都不带

Q╜先森 发表于 2017-6-23 08:04:35

还有%11.9f的11貌似没用 怎么改都行

wuyuan2011woain 发表于 2017-6-23 09:44:26

第一个问题
%f:不指定宽度,整数部分全部输出并输出6位小数。

第二个问题
用%d格式化浮点,和浮点数的存储结构有关系,你可以查一下单进度float存储格式,printf在进行参数入栈时是根据实参的类型进行入栈,而不是根据格式化字符中指定的类型,,内存中会以整数格式存储浮点,你可以反汇编一下,就知道了

第三个问题
%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。

球球chenjay 发表于 2017-6-27 16:21:43

%.x f x表示显示几个小数位 如果不写 默认小数点后无数字
% d是输入输出整型我记得
页: [1]
查看完整版本: float问题