本文测试的环境是centos 7, 使用的编译器为 GCC
#include<stdio.h>
int main()
{
int i = 5;
printf("%d, %d, %d\n", i++,i,++i);
return 0;
}
printf输出结果为 6,7,7
在查看了反汇编和 其他人相关博客后 得出如下结论 :
首先我们要明白 printf 参数计算的顺序, 计算缓冲区的概念,参数计算完毕入栈的顺序
首先计算顺序是从右往左的,计算结果存在缓冲区中
i++ 会将i 原本的值 放入寄存器(eax)中, 然后将i加一,入栈的是寄存器中的值;
++i 直接将i加一 ,等所有计算结束后统一入栈;
i 运算过程中不变,等所有计算结束后统一入栈;
例子如下:
i = 5
printf(“%d, %d,%d”, i++,i,++i); 由上述分析可得
从右往左计算 ++i 此时缓冲区中 i = 6
i 没有计算 此时缓冲区 i = 6
i++ 将缓冲区中的 i 送往寄存器eax( 6) , 然后将缓冲区中的 i =6 + 1 = 7
所以计算完毕 缓冲区的 i 为7 而寄存器中 i 为 6
从右向左压栈, 7 7 6,
打印结果出栈为 6 7 7
但是用 clang编译器 会有警告,而且打印结果又不一样了 所以还和编译器有关
总结 : 这样写代码的人已经被打死了
版权声明:本文为kwinway原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。