有时候有这道面试题;
int a=5,b=7,c; c=a+++b;
在VC++里面看一下;

输出;
首先(a++)+b 和a+++b俩个表达式概念是一样的,是一个意思
a++,++在后面的时候,先保留a的运算,a全部运算完后a才自加;
在C语言中,对于代码的分界采用的是贪心算法,也就是从按照从左到右可以组合的最大字符数来划分。
官方解释:每一个符号应该包含尽可能多的字符。也就是说,编译器将程序分解成符号的方法是,从左到右一个字符一个字符的读入,如果该字符可能组成一个符号,那么再读入下一个字符,判断已经读入的两个字符组成的字符串是否可能是一个符号的组成部分;如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串已不再可能组成一个有意义的符号。
a+++++b
按照贪心算法来算,a+++++b可以分解成:
((a++)++)+b
因为a++的结果为左值,而左值不能再进行运算,故a+++++b编译不能通过
本文探讨了C语言中a+++b表达式的含义和编译规则。在VC++环境中,由于C语言采用贪心算法划分符号,a+++b实际上等同于(a++)+b,而a++的结果为左值,不能再次运算。如果写成a+++ ++b,则根据贪心算法变为(a++)+(++b),可以编译通过。面试中遇到此类问题,理解其背后的编译原理是关键。
订阅专栏 解锁全文
1万+

被折叠的 条评论
为什么被折叠?



