故事发生在2019.7.15的3.pm,正在复习数据结构题目,写了一句如下指令(以下函数运行在win10的dev编译器下面)
#include<bits/stdc++.h> using namespace std; int main(void){ int a = 0; printf("%d ", a++); // printf("%d%d ", a++, ++a); return 0; }
发现2条语句输出不一样,你敢信?前面输出0,后面输出1,2,心态瞬间就崩了,同为a++,2次结果输出不一样!!!随后找了晗神和谢大佬,2位大佬给出的答案不一样
晗神(centos的g++运行环境):前面是0,后面是0,1 ( 和我一样,当场崩溃,怀疑是编译器原因)
谢大佬:不同编译器结果不同!!!(顿悟为什么晗神和自己输出结果不一样)
--------------------------------------------------------------- ------------------------------------------------------------------
----------------------------------------个人建议:后面内容没必深入了解,只要注意别将a++,a--,--a,++a一起输出就好 ------------------------
-------------------------------------------------------------------------------------------------
但是为什么我会输出1,2呢?
汇编语言解释一下(以i++,--i为例)
这三句汇编中执行了–操作,说明,printf函数中,两个i,先计算–i,然后计算i++,然后计算--i.
这三句话做了一下的事情:
1.将i从内存中取出来,然后存入到寄存器中。
2.将寄存器中的值-1。
3.将寄存器中减过1得值存入到内存地址中去。
总结:前置减减,是对值做了减操作后,将其存入到原来的位置。
简单来说:就是先-i,然后计算i++,再算--i, 也就是说(i = 0,结果会输出-1, 0)
全部列出来:
#include<bits/stdc++.h> using namespace std; int main(void){ int a = 0; // printf("%d ", a++); //输出0 // printf("%d%d ", a++, ++a); //输出1 2 // printf("%d%d ", a++, a++); //输出1 0 --- // printf("%d%d ", a++, --a); //输出-1 0 // printf("%d%d ", a++, a--); //输出-1 0 // printf("%d%d ", ++a, ++a); //输出2 2 // printf("%d%d ", ++a, a++); //输出2 0 --- // printf("%d%d ", ++a, --a); //输出0 0 // printf("%d%d ", ++a, a--); //输出0 0 return 0; }
但是a++, a++ 与 ++a,a++输出结果不符合道理,然后看下面这篇博客
https://blog.csdn.net/findgeneralgirl/article/details/78376834
总结了一句话:猜测:a++放的是临时变量,++a是直接计算,
假设a = 0
也就是说a++,a++这样,先将a++压栈,临时变量a + 1,然后输出a++(输出1),但是临时变量不影响后面a++的值,所以 a++依然是0
而对于a++,++a这样,先压栈,临时变量a + 1,然后输出a++(输出1),临时变量影响++a的值,所以++a是2
后面运算--a,a++,--a,a--之类的也满足上面的观点
由于不同编译器运行结果不一样,所以没事最好别把a++,++a写到一条语句里面
拓展(湖南大学2012年研究生入学真题):
1.a = 2,b = 3, b+=(++a)+(++a)
分析:b += 优先级最低,最后面算,先拆2个括号a = 4,b += (4 + 4) ,b = 11
2.i = 5, i+++i
分析: ++优先级比+高,所以i = 6即(i++) + i = 5 + 6 = 11,若改成(++i) + i = 6 + 6 = 12