|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 Blitz 于 2019-12-24 06:20 编辑
#include <stdio.h>
void main()
{
float a=123.123;
double b=12345678.1234567,c;
c=a+b;
printf("%f,%f\n",(float)c,a);
}
这个程序最后的结果是12345801.246458是双精度可是我已经在printf里强制转换了呀?
而且如果把c换到float里面
#include <stdio.h>
void main()
{
float a=123.123,c;
double b=12345678.1234567;
c=a+b;
printf("%f,%f\n",c,a);
}
得到的结果就是12345801.000000的单精度了
按道理来讲,强制转换后就该是降低精度的呀。。。我这里用你的程序试了一下,强制转换之后得到的结果就是12345801.000000的单精度。不知道你用的是什么编译器,电脑是多少位的?这个可能与编译器有关。
另外不要绝对的相信任何书本。很多教材上都是说float和double与系统位数无关,float都是4字节,double都是8字节。但是真正用的时候,还是要看自己的编译器,编译器才是把程序翻译成机器语言的工具,不同的编译器翻译结果很可能会有差异。
|
|