//floatcnv
#include<stdio.h>
int main(){
float n1=3.0;
double n2=3.0;
long n3=2000000000;
long n4=1234567890;
printf("%.1e %.1e %.1e %.1e\n",n1,n2,n3,n4);
/*n1 float的值作为printf的参数时会被转为double类型,由4字节扩大到8字节
%e 解释打印long类型n3时,会查n3本身的4字节内容以及相邻的4字节内容,并把这8字节单元中的位组合解释成浮点数
因此,printf中用%e解释打印long类型的变量会得到无意义的值*/
printf("%ld %ld\n",n3,n4);
//正确使用了转换说明,成功打印了n3和n4
printf("%ld %ld %ld %ld\n",n1,n2,n3,n4);
/*程序把传入的值放入栈中,n1-n4依次入栈,分别占8字节(float被转换为double)、8字节、4字节、4字节,
然后printf函数根据转换说明从栈中读取值,前4个字节为第一个值,以此类推,即使n3、n4的转换说明对了,但printf依然读错了字节*/
return 0;
}
第4个printf因系统不同有不同的输出