今天无意间看到一个讲关于自加的问题,便一发不可收拾,研究了好一阵 。
一道简单的题目引发的思考
该博主从j = (i++) + (i++) + (++i)
的输出开始,研究了各编译器的输出结果,并且分析了各个编译器出现结果是如何计算的。先不管其他,下面是我对此问题的理解。
(1)在size运算中,前置++/–的结合优先级最高,后置++/–的优先级最小,
所谓结合顺序,就是指分析表达式时操作数与哪个运算符相结合的意思。
例如有表达式:1+2,在这个表达式中只有一个运算符+,所以所有的操作数都与这个运算符结合,计算结果是1加上2等于3。
如果我们加上一个结合优先级高的运算符例如乘:1+2*3。此时由于*比+结合优先级高,所以会把操作数2抢先与其结合,运算结果是1加上2乘以3的结果6,最终结果是7。换言之1+2*3 === 1+(2*3)而不是(1+2)*3,这就是运算符优先级的含义。
(2)在GCC中假发运算中是从左向右开始计算的。
下面是我在64 bit centos 中用G++ 编译的小实验,可以看一下结果到底是什么。
#include<iostream>
using namespace std;
int main()
{
int a = 3,b = 3, c = 3, d = 3, e = 3