本篇内容介绍了“C语言操作符++和--怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一、++与--操作符的本质
++ 和 -- 操作符对应两条汇编指令
前置
变量自增(减)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;}
在 VS2012中,它的运行结果如下:
在 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;}
运行后编译器会报错:
这行代码为什么报错呢?int j = ++i+++i+++i;
原因就是编译器发现 ++i 后由于贪心,会继续往下找,发现 ++i+ 后编译器觉得符合语法规则,继续往下找,当出现 ++i++时编译器感觉不对,开始计算,就变成 1++,这是不合法的,所以编译器就会报错。
空格可以作为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语言操作符++和--怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!