今天下午,我真的不知道我在操作员和C上做了什么。最后,我写了一些我认为无法编译的代码,但我不知道它是如何工作的。
代码是:
#include <stdio.h>
int main()
{
int n=2;
int sum = n + - + - + - + n; /* This line */
printf("%d\n", sum);
return 0;
}
输出是:
0
我完全混淆了代码编译方式以及幕后发生的事情。
行int sum = n + - + - + - + n;
如何运作?
答案 0 :(得分:5)
除了第一个之外的所有人都只是一元运算符。
n + - + - + - + n
相当于
n + (-(+(-(+(-(+n))))))
又等于
n + (-n)
解决所有一元运算符后。
-n
当然是普通的否定; +n
基本上没有任何作用(虽然它具有强制整体推广的副作用)。
答案 1 :(得分:4)
int sum = n + - + - + - + n;
/* b u u u u u u */
/* Order: 7 6 5 4 3 2 1 */
相当于:
n + (-(+(-(+(-(+n))))));
或只是n + (-n)
请注意,一元运算符绑定比C opeartor precedance table
中的二元运算符更紧密,并且一元运算符+-
的关联性从右到左,而二元+-
运算符的关联从左到右。< / p>
答案 2 :(得分:3)
+
和-
都是一元运算符。 +n
的结果是n
的(提升)值。 -n
的结果是(已提升)n
的否定结果。
n + - + - + - + n;
相当于:
n + (-(+(-(+(-(+n))))))
假设没有发生溢出,基本上是n + (-n)
。