#include<stdio.h> void main() { int a1=99,a2=42; char c1='d'; unsigned int u1=76,u2=65535 ; float f1=53.65f; float f2=f1; long int d1=68; printf("%d %f\n",f1,f1); printf("%f\n",f1); }
上面这段程序输出结果:
不知道大家知不知道为什么第一个输出的f1结果是不正确的
下面大概说一下printf函数
1,printf是一个不定参数的函数,所以printf函数的实现除了第一个字符串,其他类型是不知道的,只能通过字符串中的%d,%u来判断类型
2,printf参数的计算顺序是从右到左的,也就是压栈顺序是从右到左的,所以在取参数时是从左到右的
3,printf函数取第一个是%d,四个字节,但是传入的是f1,如果f1不是4个字节怎么办,那不是得不到正确的值
4,float在传入printf里自动转换成double类型变成8个字节,那么就是一个传入8+8 16个字节。而取得时候 先是%d,取了4个 又是%f 取了8个 这8个就是前面8字节的4个和后面8字节的4个,所以结果肯定不对。
int main () { int i = 0; printf ("%d,%d,%d",++i,++i,++i); }
ps:若是long long的话占64位,printf操作对一个参数要进行两次压栈操作,先是高32位,然后是低32位
int main() { long long a=1; long long b=2; long long c=3; printf("%d,%d,%d\n",a,b,c); }