回复 楼主 枫枫落雨
试验证明,a+++++b在编译时会报错,(a++)+(++b)和a++ + ++b不会报错
学过编译原理的人都知道,“a+++++b”这一段根本就无法解析,编译系统从左至右扫描整条语句,先遇到a++,判断出来是一个a的后缀自加运算,然后接着扫描,遇到一个+,+是一个二目运算符,它的左边已经有一个运算数a++了,系统就向右搜索第二个运算数,又遇到一个+,++比+的运算级别要高,这时,编译系统就将两个+看成一个整体来处理,既然是++,编译系统就认定,肯定它的左边或右边有一个变量,编译系统先搜索左边,发现++,不是变量,再搜索右边,发现+b,+b是什么东西?编译系统是无法搞明白的,因此它就认为++是一个缺少左值的自增运算符,于是提示提示用户:’++’ needs l-value
[
本帖最后由 ggyy4k 于 2010-7-26 16:03 编辑 ]