马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 ZPCG 于 2011-8-13 09:23 编辑 #include <stdio.h>]
void main()
{
int a = 15;
float b =12345.1234567;
double c =123456789.123456789;
char d ='p';
printf("a =%d, %5d, %o, %x\n", a, a, a, a);
printf("b =%f, %lf, %5.4lf, %e\n", b, b, b, b);
printf("c =%lf, %f, %8.4lf\n", c, c, c);
printf("d =%c, %d, %8c\n", d, d, d);
}
得出的结果是:
想问的:(没人回答啊,那我自己搜索了一下,自己来回答吧)
1 、 printf语句中的%5.4lf,%8.4lf中的5.4和8.4是什么意思?我知道4是表示小数位数,那小数点前面的5和8呢?
答:5或8是指显示结果的位数至少是5位或8位.
2、%f和%lf,浮点和长浮点有什么区别,从我得出的结果看没什么区别?
答:浮点型在内存中占32位,分别是:
地址 +0 +1 +2 +3
内容 SEEE EEEE EMMM MMMM MMMM MMMM MMMM MMMM
S 代表符号位,1是负,0是正
E 偏移127的幂,二进制阶码=(EEEEEEEE)-127。
M 24位的尾数保存在23位中,只存储23位,最高位固定为1。此方法用最较少的位数实现了较高的有效位数,提高了精度。
而长浮点则翻倍.
3、为什么b的结果是12345.123047?而不是12345.123456呢?.
答:根据上个问题的结论:后23位加上省略的1位,共24位,所以最大只能到2的24次方=16777216-1=16777215来表示前8位,超过的乱显示.不知道这样解释对不对.
|