--事物的难度远远低于对事物的恐惧!
这章来谈一谈也许++和--操作符,也许很多人都很熟悉这两个操作符,其实 ++ 和 -- 操作符就对应两条汇编指令:
-前置时
-变量自增(减)1
-取变量值
-后置时
-取变量值
-变量自增(减)1
那么来看看下边的这段代码,你觉得输出会是什么?
#include <stdio.h>
int main()
{
int i = 0;
int r = 0;
r = (i++) + (i++) + (i++);
printf("i = %d\n", i);
printf("r = %d\n", r);
r = (++i) + (++i) + (++i);
printf("i = %d\n", i);
printf("r = %d\n", r);
return 0;
}
我的运行环境为vs2010,执行结果如下,也许在gcc编译环境下是另一种结果:
对于 ++ 与 --两个操作符:
- C语言中只规定了 ++ 和 -- 对应指令的相对执行次序
- ++ 和 -- 对应的汇编指令不一定连续运行
- 在混合运算中, ++ 和 -- 的汇编指令可能被打断执行
结论:++ 和 -- 参与混合运算结果是不确定的!
下边再来看一个奇葩的面试题(但是在工程代码中,禁止写这种代码):
#include <stdio.h>
int main()
{
int i = 0;
int j = ++i+++i+++i;
int a = 1;
int b = 4;
int c = a+++b;
int* p = &a;
b = b/*p;
printf("i = %d\n", i);
printf("j = %d\n", j);
printf("a = %d\n", a);
printf("b = %d\n", b);
printf("c = %d\n", c);
return 0;
}
要分析上边这段代码的执行输出,我们先来了解下 ++和--表达式的阅读技巧:贪心法
-编译器处理的每个符号应该尽可能多的包含字符
-编译器以从左到右的顺序一个一个尽可能多的读入字符
-直到读入的字符不可能和已读入的字符组成合法符号为止
-空格可以作为C语言中一个完整符号的休止符,编译器读入空格后立即对之前读入的符号进行处理
有了“贪心法”这个准则,你能分析出这道面试题了吗?
总结:
1、++ 和 -- 操作符在混合运算中的行为可能不同
2、编译器通过贪心法处理表达式中的子表达式
3、空格可以作为C语言中一个完整符号的休止符
4、编译器读入空格后立即对之前读入的符号进行处理