目录
  • 一、++与–操作符的本质
  • 二、++与– 操作符使用分析
  • 三、小结

一、++与–操作符的本质

++ 和 — 操作符对应两条汇编指令

前置

  • 变量自增(减)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中,它的运行结果如下:

C语言简明讲解操作符++和--的使用方法

在 gcc 编译器中,它的运行结果如下:

C语言简明讲解操作符++和--的使用方法

这是由于不同编译器对 ++ 和 — 的相对哦执行次序不一样。

二、++与– 操作符使用分析

  • C 语言中只规定了 ++ 和 — 对应指令的相对执行次序
  • ++ 和 — 对应的汇编指令不一定连续运行
  • 在混合运算中,++ 和 — 的汇编指令可能被打断执行

++ 和 — 参与混合运算结果是不确定的。

笔试面试中的“奇葩”题

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语言简明讲解操作符++和--的使用方法

这行代码为什么报错呢?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语言简明讲解操作符++和--的使用方法

三、小结

  • ++ 和 — 操作符在混合运算中的行为可能不同
  • 编译器通过贪心法处理表达式中的子表达式
  • 空格可以作为C语言中一个完整符号的休止符
  • 编译器读入空格后立即对之前读入的符号进行处理
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。