C语言操作符++和--怎么使用

发布时间:2022-04-19 17:09:45 作者:iii
来源:亿速云 阅读:119

本篇内容介绍了“C语言操作符++和--怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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

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

前置

后置

下面看一段神奇的代码:

#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语言操作符++和--怎么使用

贪心法:++,-- 表达式的阅读技巧

下面看一段代码:

#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语言操作符++和--怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

推荐阅读:
  1. c语言操作符小结
  2. C语言操作符自我总结

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c语言

上一篇:Python操作ES的方式及与Mysql数据同步的方法

下一篇:node环境和浏览器环境有哪些区别

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》