初识C语言:自增与自减陷阱

简介: 初识C语言:自增与自减陷阱

一个整数类型的变量自身加 1 可以这样写:

a = a + 1;

a += 1;

当然,C语言还支持有另外一种更加简洁的写法,就是:a++ ++a,这种写法我们称之为自增

与之对应的,也有 a-- --a ,即自减,其表示自身减 1。

但++和--放在前面和后面有什么区别呢?

参考如下代码

#include<stdio.h>
 
int main()
{
    //++ -- 自增,自减 一元运算符
    
    int a = 3;
    int b = a++; //a++ a = a + 1; //执行完这代码后,先给b赋值,再自增
                     
    printf("%d\n",a); 
      
    int c = ++a;//++a a = a + 1;//执行完这行代码前,先自增,再给c赋值
    
    printf("%d\n",a);   
    printf("%d\n",b);
    printf("%d\n",c);     
    return 0;
}


运行结果如下:

让我们来先来了解一下前置和后置的区别:

前置++ 是先进行自增运算,再返回自增之后的结果;

后置++ 是先返回自增之前的结果,再进行自增。


我们对上述代码一行行分析


先给a赋值为3,a++先返回自增前a的值,a再自增,也就是先把a=3赋值给b,此时b=3,a自增之后a=4;


打印出a的结果为4


此时++a,先对a进行自增,a=5,再将a赋值给c,此时c=5


此时a=5


      b=3


      c=5


打印出结果


泊舟说:“此次的内容很少,但确是一个很容易错误的问题,希望大家都能很好的掌握~”

目录
打赏
0
0
0
0
7
分享
相关文章
C语言运算符——自增与自减
自增与自减 一个整数类型的变量自身加 1 可以这样写: a = a + 1;或者a += 1;不过,C语言还支持另外一种更加简洁的写法,就是:a++;或者++a;这种写法叫做自加或自增,意思很明确,就是每次自身加 1。 相应的,也有a–和--a,它们叫做自减,表示自身减 1。++和–分别称为自增运算符和自减运算符,它们在循环结构中使用很频繁。
291 0
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言入门——自增,自减运算(逐行逐句分析)
C语言入门——自增,自减运算(逐行逐句分析)
360 0
C语言入门——自增,自减运算(逐行逐句分析)
C语言自增(++)和自减(--)
对于自增自减的相关用法
276 0
C语言自增(++)和自减(--)
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
213 0
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
186 23
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
32 1
一文彻底搞清楚C语言的函数
|
3月前
|
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
167 15
|
3月前
|
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
84 24
|
3月前
|
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
173 16
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等