float n1 = 3.0;
double n2 = 3.0;
long n3 = 2000000000;
long n4 = 1234567890;
long n5 = 250;
long n6 = 213;
printf("%ld %ld %ld %ld %ld %ld\n",n1,n2,n3,n4,n5,n6);//第五个和第六个%ld对应输出是什么?别试代码,直接看哦~!
long类型是4字节
float是4字节
double为8字节(但是为什么他俩都是占两个位置我还忘了~~对了,当被用作printf()的参数时,float自动转换为double)
n5和n6输出的是n3和n4的值,因为格式控制强制要求long类型的数据输入,(记不清了。。。)原理就是一个堆栈,按顺序往里铺,一个浮点型的占了两个位置,所以整体后延了两个位置。甚至于控制格式使用8个%ld,能在七八号位看到250和213.
相应地,一个普通的long int型,如果对应%e或者%lf之类的浮点型控制符,会和其后的4位组合,导致一个不是期待的数被打印,这也变相压缩了堆栈,第五六个位置就能打印出n1和n2。
//附加的,可以添加两个格式控制符和减少两个格式控制符,没有严格限制
printf("%ld %ld %ld %ld %ld %ld %ld %ld\n",n1,n2,n3,n4,n5,n6);//8个控制符对应6个参数,最后两个打印正确
printf("%e %e %e %e %e %e\n",n1,n2,n3,n4,n5,n6,n1,n2);//6个控制符对应8个参数,最后两个打印正确