C语言自增(++)和自减(--)

简介: 对于自增自减的相关用法

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

14.png

或者

1.png

不过,C语言还支持另外一种更加简洁的写法,就是:

2.png

或者

3.png

这种写法叫做自加自增,意思很明确,就是每次自身加 1。

相应的,也有 a----a,它们叫做自减,表示自身减 1。

++-- 分别称为自增运算符自减运算符,它们在循环结构中使用很频繁。

自增和自减的示例:

4.png

自增自减完成后,会用新值替换旧值,将新值保存在当前变量中。


自增自减的结果必须得有变量来接收,所以自增自减只能针对变量,不能针对数字,例如 10++就是错误的。


需要重点说明的是,++ 在变量前面和后面是有区别的:

  • ++ 在前面叫做前自增(例如 ++a)。前自增先进行自增运算,再进行其他操作。
  • ++ 在后面叫做后自增(例如 a++)。后自增先进行其他操作,再进行自增运算。

自减(–)也一样,有前自减和后自减之分。


下面的例子能更好地说明前自增(前自减)和后自增(后自减)的区别:

5.png


a、b、c、d 的输出结果相信大家没有疑问,下面重点分析 a1、b1、c1、d1:

1.对于 a1=++a,先执行 ++a,结果为 11,再将 11 赋值给 a1,所以 a1 的最终值为11。而 a 经过自增,最终的值也为 11。


2.对于b1=b++,b 的值并不会立马加 1,而是先把 b 原来的值交给 b1,然后再加 1。b 原来的值为 20,所以 b1 的值也就为 20。而 b 经过自增,最终值为 21。


3.对于c1=--c,先执行 --c,结果为 29,再将 29 赋值给c1,所以 c1 的最终值为 29。而 c 经过自减,最终的值也为 29。


4.对于d1=d--,d 的值并不会立马减 1,而是先把 d 原来的值交给 d1,然后再减 1。d 原来的值为 40,所以 d1 的值也就为 40。而 d 经过自减,最终值为 39。

  • 可以看出:a1=++a; 会先进行自增操作,再进行赋值操作;
  • b1=b++; 会先进行赋值操作,再进行自增操作。c1=--c;d1=d--; 也是如此。

为了强化记忆,我们再来看一个自增自减的综合示例:

6.png


我们来分析一下:

       1.执行语句①时,因为是后自减,会先进行 a-b 运算,结果是 11,然后 b 再自减,就变成了 0;最后再将 a-b 的结果(也就是11)交给 c,所以 c 的值是 11。


       2.执行语句②之前,b 的值已经变成 0。对于d=(++a)-(--b),a 会先自增,变成 13,然后 b 再自减,变成 -1,最后再计算 13-(-1) ,结果是 14,交给 d,所以 d 最终是 14。

我再给读者加一个,C++ 的程序示例:

示例一:

7.png

示例二:

8.png

不管是自增运算符,还是自减运算符,它们只能作用于可变左值,而不能表达式,如下:

9.png

目录
相关文章
|
3月前
|
C语言
初识C语言:自增与自减陷阱
初识C语言:自增与自减陷阱
|
C语言
C语言运算符——自增与自减
自增与自减 一个整数类型的变量自身加 1 可以这样写: a = a + 1;或者a += 1;不过,C语言还支持另外一种更加简洁的写法,就是:a++;或者++a;这种写法叫做自加或自增,意思很明确,就是每次自身加 1。 相应的,也有a–和--a,它们叫做自减,表示自身减 1。++和–分别称为自增运算符和自减运算符,它们在循环结构中使用很频繁。
242 0
|
C语言 C++
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
C语言经典实例:1-10例:三角求和、显示所占字节数、自增自减运算while语句输出最小值、计算快递费用、学生成绩统计
|
C语言
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
339 0
宏定义可以自增自减吗?(带题讲解,并总结C语言数据类型可自加自减的)
|
C语言
C语言入门——自增,自减运算(逐行逐句分析)
C语言入门——自增,自减运算(逐行逐句分析)
332 0
C语言入门——自增,自减运算(逐行逐句分析)
|
存储 Java C语言
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
195 0
|
1月前
|
存储 C语言 开发者
【C语言】字符串操作函数详解
这些字符串操作函数在C语言中提供了强大的功能,帮助开发者有效地处理字符串数据。通过对每个函数的详细讲解、示例代码和表格说明,可以更好地理解如何使用这些函数进行各种字符串操作。如果在实际编程中遇到特定的字符串处理需求,可以参考这些函数和示例,灵活运用。
72 10
|
1月前
|
存储 程序员 C语言
【C语言】文件操作函数详解
C语言提供了一组标准库函数来处理文件操作,这些函数定义在 `<stdio.h>` 头文件中。文件操作包括文件的打开、读写、关闭以及文件属性的查询等。以下是常用文件操作函数的详细讲解,包括函数原型、参数说明、返回值说明、示例代码和表格汇总。
56 9
|
1月前
|
存储 Unix Serverless
【C语言】常用函数汇总表
本文总结了C语言中常用的函数,涵盖输入/输出、字符串操作、内存管理、数学运算、时间处理、文件操作及布尔类型等多个方面。每类函数均以表格形式列出其功能和使用示例,便于快速查阅和学习。通过综合示例代码,展示了这些函数的实际应用,帮助读者更好地理解和掌握C语言的基本功能和标准库函数的使用方法。感谢阅读,希望对你有所帮助!
45 8
|
1月前
|
C语言 开发者
【C语言】数学函数详解
在C语言中,数学函数是由标准库 `math.h` 提供的。使用这些函数时,需要包含 `#include <math.h>` 头文件。以下是一些常用的数学函数的详细讲解,包括函数原型、参数说明、返回值说明以及示例代码和表格汇总。
55 6