c语言中a+++++b应该怎么理解?
4个回答
展开全部
展开全部
a+++++b在编译时会报错,(a++)+(++b)和a++ + ++b不会报错
“a+++++b”这一段根本就无法解析,编译系统从左至右扫描整条语句,先遇到a++,判断出来是一个a的后缀自加运算,然后接着扫描,遇到一个+,+是一个二目运算符,它的左边已经有一个运算数a++了,系统就向右搜索第二个运算数,又遇到一个+,++比+的运算级别要高,这时,编译系统就将两个+看成一个整体来处理,既然是++,编译系统就认定,肯定它的左边或右边有一个变量,编译系统先搜索左边,发现++,不是变量,再搜索右边,发现+b,+b是什么东西?编译系统是无法搞明白的,因此它就认为++是一个缺少左值的自增运算符,于是提示提示用户:’++’ needs l-value
另外,假如定义int a = 1,b = 2;
c = a++ + ++b;
1:先执行b自加,b变为3;相当于:b = b+ 1;
2:求a与b之和,赋给c;相当于:c = a + b ;//c = 1+3;
3:执行第二步之后,a自加1:a++;
4:如果要输出的话,(按执行顺序)
b = 3;
c = 4;
a = 2;
“a+++++b”这一段根本就无法解析,编译系统从左至右扫描整条语句,先遇到a++,判断出来是一个a的后缀自加运算,然后接着扫描,遇到一个+,+是一个二目运算符,它的左边已经有一个运算数a++了,系统就向右搜索第二个运算数,又遇到一个+,++比+的运算级别要高,这时,编译系统就将两个+看成一个整体来处理,既然是++,编译系统就认定,肯定它的左边或右边有一个变量,编译系统先搜索左边,发现++,不是变量,再搜索右边,发现+b,+b是什么东西?编译系统是无法搞明白的,因此它就认为++是一个缺少左值的自增运算符,于是提示提示用户:’++’ needs l-value
另外,假如定义int a = 1,b = 2;
c = a++ + ++b;
1:先执行b自加,b变为3;相当于:b = b+ 1;
2:求a与b之和,赋给c;相当于:c = a + b ;//c = 1+3;
3:执行第二步之后,a自加1:a++;
4:如果要输出的话,(按执行顺序)
b = 3;
c = 4;
a = 2;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
(a++)+(++b)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询