C++其实有一些特别古怪的语言特点,举个例子吧:
i++ + ++i;
这样的代码不光可读性不好,其结果在不同的编译环境下,其结果也可能不一样,我们根本不知道i会在什么时候递增。我们也不知道写出这样代码的同学的编程目的是什么;我们要使用C++语言的特性,可以写出如下的代码:
a[i] = ++i;
这样就舒服多了,要表达的信息是对名字为a的数组的某一个元素赋值,我们解释一下结果,假如原来i=2,这一行代码先执行++i,也就是先将i自增1,这样我们就是在给a[3]进行赋值,然后将自增后的i也就是3赋值给了a[3]。对这段代码稍微做一下修改:
a[i++] = ++i;
上面的分析依然正确,只是在a[3]=3之后,i变成了4;再稍作修改:
a[++i] = ++i;
这段儿代码可能就不那么好解释了,但我还是勉为其难地解释一下吧,编译器首先对等式右边的i进行自增,如果i为2,这时候右边的值就变成了3,然后左边i在3的基础上继续自增1,就变成了要对a[4]进行赋值,也就是a[4]=3。这时候的你,是慨叹于C++语言的强大呢,还是无语凝噎呢?反正我是不想把功夫浪费在这上面,看到这样的代码,我一定会大刀阔斧地修改成可读性强的,哪怕看起来稍微有点臃肿呢,也不用这些极容易产生歧义的代码。