首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

c语言:自增自减运算符的操作详解

博主在回忆c语言的基本知识时,突然发现自增自减运算符(--、++)这个知识点有些模糊不清,故博主为了给同为小白的同学们提供一些经验,特写下这篇文章。 首先,自增自减运算符共有两种操作方式。...#include //自增自减运算符的测试 int main() { int a = 21; int c; c = a--; printf("%d\n", c); a = 21...由此可知,我们可以得到一个结论:诸如“a++”类自增自减运算符在变量之后的,进行操作时是先赋值,后运算;而“++a”类的操作则正是与此相反。...以c=a++为例,由上述结论可知,这个表达式实际上是先将a的值赋给c,这样c就等于21,而后续符号操作的则直接是a,所以经过这个表达式之后,a的值实际上变成了22。由此,则可以推出下面的一系列内容。...这篇文章主要是针对c语言小白,各位大神还请借道哈,不要喷我,如果有错误还请帮忙指出,不胜感激。 本人也是小白一枚,愿与诸君共同进步,通向成神之路!!!

2.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    2.1 C++自增自减运算符

    自增运算符 在C++中,常常使用自增运算符(++),来使变量的值增1 i++ int i=3; int j; i++; j=i++; 在使用i之后,先让i的值加1,比如上述代码,执行j=i++之后,...j的值是3,i的值才是4 ++i int i=3; int j; ++i; j=++i; 在使用i之前,先让i的值+1,上述输出j后,j的值为4 自减运算符 i-- int i=3; int j;...执行后,j的值为2 在使用自增自减运算符的时候要注意以下几点 自增和自减运算符都是用于变量,不能用于常量或者表达式。...自增和自减运算符结合方向的规则是自右向左,和前面小节将的自左向右正好相反。 自增和自减运算符在C++中主要用于循环语句中,使循环变量的值自动+1或者-1。...自增和自减运算符也用于指针变量中,可以使指针指向下一个地址,和C语言类似。

    6943230

    EasyC++20,C++中的自增与自减

    这是EasyC++系列的第20篇,简单聊聊C++当中的自增与自减。 自增与自减 基本用法 自增与自减是C++当中两个使用频率非常高的运算符,不仅在循环当中用到,在日常的代码当中也经常使用。...甚至C++这个名称的由来都和自增运算符有关,表示C语言的升级版。当然这也是C#名字的由来,#这个符号表示4个叠加的加号……不得不吐槽这微软的恶趣味。...对此,C++当中有一个叫做顺序点的概念,顺序点指的是程序执行过程中的一个点。在C++当中语句中的分号就是一个顺序点,在程序处理下一条语句之前,赋值运算符、自增、自减运算符执行的所有修改都必须完成。...意味着我们在执行cout之前,cnt变量就已经完成了自增。这进一步说明了while(cnt++ C++就会完成自增的操作。...指针自增、自减 自增自减操作同样可以运用在指针上,前文当中介绍过,这表示指针的移动。自增表示向右移动一位,自减表示向左移动一位。 这很简单,但是当我们把一些操作符结合在一起就有些麻烦了。

    67530

    C语言 枚举类型在VS2010上无法实现自增,自减操作

    如果一个变量只有几种可能的值,那么这个变量可以被定义为枚举类型。 枚举的意思就是把可能的值一一列举出来,那么变量的值也只限于列举出来的范围中。...5.C99标准把枚举类型作为一种整型数据,所以枚举类型是应该支持自加一操作的,《谭浩强 C程序设计》中也应用了枚举类型自加的操作,比如我们写这样一个代码: #include int...black;i++) { printf("当为第%d个颜色\n",i); } getchar(); return 0; } 这时应该打印出4列话才对,但是我用vs2010 把文件后缀改成.c,...所以我只能理解为微软对C语言的支持不是太好,C99中的一些特性并没有支持。...换个角度想,其实应用枚举类型自加操作本身也不太好,当我们使用默认的顺序而不是在声明时指定,枚举元素才是连续的,指定后元素将不再连续,比如 #include int main() {

    77520

    C++ 自增、自减运算符的重载和性能分析

    — 1 — 重载的形式 自增运算符和自减运算符是有「前置」和「后置」之分的,如: a++ // 后置自增运算符 ++a // 前置自增运算符 b-- // 后置自减运算符 --b // 前置自减运算符...为了区分所重载的是「前置」运算符还是「后置」运算符,C++规定: 「前置」运算符作为一元运算符重载,重载为成员函数的形式如下: // 前置自增运算符的重载函数,函数参数是空 T & operator+...首先我们先定义好 CDemo 类,同时也把自增、自减运算符重载函数定义好,代码如下: ? 接着继续实现「前置」自增、自减运算符重载函数: ?...「后置」自增、自减运算符重载,就有点不同,例如后置++,是先参与运算,再进行自增,所以返回值是没自增前的对象,具体实现如下: ?...---- — 4 — 性能比较 从上面的例子,我们看到「后置」运算符的重载函数的执行步骤: 先要产生一个临时对象来保存未自增或自减前的对象; 接着成员变量自增或自减; 最后返回修改前的对象(临时对象);

    1.1K20

    编程小知识之 自增(自减)运算符

    本文链接:https://blog.csdn.net/tkokof1/article/details/102795683 本文讲述了 C/C++ 中 自增(自减)运算符 的一些知识~ 自增(自减...)运算符应该是 C/C++ 编程中的基础知识了,而自增(自减)运算符又有两种形式,分别是 前置自增(自减) 和 后置自增(自减) (出于简单考虑,后文仅以自增运算符进行举例讲解)....虽然就现在的程序开发来讲,似乎我们已经不必特别关心 前置自增 和 后置自增 的效率差异了,在合适的情况下,编译器对于 前置自增 和 后置自增 也能生成同样高效的汇编代码了,但是自己依然坚持着上面的编码习惯...这里的原因是 前置自增 会比 后置自增 产生更多的 指令流水线停顿(stall),一般情况下,虽然 前置自增 对比 后置自增 会产生更少的指令操作,但是其产生的指令流水线停顿对效率的影响更大,所以我们应该...后面就是简单的测量运行时间了,结果也确实如书中所说: 后置自增 平均要比 前置自增 快 20% 左右 ~ 总结 多用后置自增,少用前置自增,虽然 后置自增 会产生更多的指令操作,但是一般情况下对指令流水线的影响更小

    1.1K20

    高并下如何做变量的自增与自减

    1变量的自增与自减 变量的自增自减相信大家都会,一般情况下直接++或--就可以了。但是实际情况我们可能需要考虑并发问题,多线程情况下,如果我们直接计算。计算结果可能就会不准确。...2加锁的自增与自减 这时我们就会给运算方法加锁,synchronized或者lock都行 public static synchronized void increaseWithSync() { num...这是我们就要使用JDK自带的原子类了。 3原子自增与自减 我们来看看java.util.concurrent.atomic包下面的原子类AtomicInteger。...4分布式系统中的自增与自减 我们来看这样一个需求: 用户注册就会给用户分配一个编号,编号规则按用户先后注册顺序递增,比如第一位注册的用户编号为100,第二位就为101,依次类推。...由于Redis的主计算线程属于单线程,使用Redis安全又高效。 Java有个Redis的API RedissonClient可以用来实现原子自增与自减。

    77210

    【说站】java自增自减运算符有哪些?

    java自增自减运算符有哪些? 说明 1、自我增加(++)自我减少(-)运算符是一种特殊的算术运算符,它需要两个操作数来运算,而自我增加自我减少运算符是一个操作数。...2、前缀自增自减法(++a,-a):进行自增或自减操作,然后进行表达式操作。 3、后缀自增自减法(a++,a-):先进行表达式操作,再进行自增或自减操作。...String[] args) {     int a = 5;//定义一个变量;     int b = 5;     int x = 2 * ++a;     int y = 2 * b++;     //自增运算符前缀运算后...a=6,x=12     System.out.println("自增运算符前缀运算后a=" + a + ",x=" + x);     //自增运算符后缀运算后b=6,y=10     System.out.println...("自增运算符后缀运算后b=" + b + ",y=" + y); } 以上就是java自增自减运算符的介绍,希望对大家有所帮助。

    88430

    Java自增自减运算符神坑笔试题

    问:下面程序运行的结果是什么?...,返回值是count自加前面的值,java对自加处理的流程是先把count的值(不是引用),拷贝到一个临时变量区,然后对count变量加1,接着返回临时变量区的值。...所以上面代码中第一次循环执行的步骤是JVM把count的值(0)拷贝到临时变量区,然后count值加1,这时count的值是1,接着返回临时变量区的值(值还是0),最后赋值给count,此时count值被重置成...0,其他99次的循环也是一样,最终导致count的值始终没变,任然保持最初的状态,如果想要打印100,则把语句count = count++改为count++即可。...不过这个问题在不同的语言环境中是不一样的,在c++中count = count++与count++是等效的,但在Java中是不等效的。

    1.7K30

    【面试题精讲】Java自增自减运算符

    什么是自增自减运算符? 自增自减运算符是一种用于对变量进行加 1 或减 1 操作的特殊运算符。在大多数编程语言中,自增运算符表示将变量的值增加 1,而自减运算符表示将变量的值减少 1。...自增自减运算符的实现原理? 自增自减运算符的实现原理与编程语言相关。在大多数编程语言中,自增自减运算符都是通过修改变量的值来实现的。...对于前缀形式的自增自减运算符,编译器会先将变量的值加 1 或减 1,然后再返回结果;对于后缀形式的自增自减运算符,编译器会先返回原始值,然后再将变量的值加 1 或减 1。 4....自增自减运算符的优点 简化代码:使用自增自减运算符可以简化对变量进行加 1 或减 1 操作的代码。...可能影响性能:某些编程语言对于自增自减运算符的实现可能存在性能问题,尤其是在循环中频繁使用时。 7.

    30330

    Java基础知识整理,驼峰规则、流程控制、自增自减

    Java基础知识整理,注释、关键字、运算符在这一篇文章中我们总结了包括注释、关键字、运算符的Java基础知识点,今天继续来聊一聊命名规则(驼峰)、流程控制、自增自减。...三、自增自减 在上面for循环的代码示例中我们可以看到很多整数类型的++符号,用以实现循环内部的自增,类似的还有自减--符号,既可以放在整形前也可以放在整形后,区别是:符号在前就先加/减,符号在后就后加.../减。...直接通过一段代码示例感受一下:自加 public class TestAdd { public static void main(String[] args) { int a...System.out.println("x=" + x); System.out.println("y=" + y); } } 输出: a=4 b=3 x=4 y=4 自减

    8500

    Redis类型 自增自减实现追加 ,获取字符串长度

    字符串类型是redis中最基本的数据类型,它能存储任何形式的字符串(一般字符串,序列化的字符串),一个字符串类型键允许存储的数据最大容量是512MB。...注意memcache最大的value值只有1M 递增数字INCR key 当存储的字符串是整数时,redis提供了一个实用的命令INCR,其作用是让当前键值递增,并返回递增后的值。...DECR自减 减少指定的整数 DECR key DECRBY key number ? Append追加 向尾部追加值。...如果键不存在则创建该键,其值为写的value,即相当于SET key value。返回值是追加后字符串的总长度。 语法:APPEND key value ?...来源:https://jingyan.baidu.com/article/49711c61866538fa441b7cb5.html

    2.9K30

    C语言printf中的自增运算符

    解析: C语言中,++i表示先运算后赋值,i++表示先赋值后运算。这个知识点相信只要会点编程的人都知道。 而C语言中,printf中自增自减运算符却有另一片天地。...其实上面例子如果将C语言代码换成汇编语言,能清晰的看出来代码的执行流程,只是放出来汇编代码怕是不懂汇编的就更懵了。 所以这里我就不放汇编了,直接用最通俗的方式记录我的理解。...,编译器会将运算前的值存储在寄存器中,以便在运算完成之后运行输出,所以后面输出的其实是寄存器中之前存储下来的值。...而像++i这样先运算后赋值的情况则无需寄存器来保存运算之前的值,因为运算之前的值保存下来毫无意义,它会输出运算之后的值。 i--和--i同理。...dx=ax+1=6 movl %edx, -4(%rbp) // 将dx寄存器的值赋值给i, i=dx=6 ++i的汇编代码: addl $1, -4(%rbp) // 将i的值增加1赋值给i, i=

    84810

    mysql 主键自增语句_MySQL 自增主键

    自增主键有两个性质需要考虑: 单调性 每次插入一条数据,其 ID 都是比上一条插入的数据的 ID 大,就算上一条数据被删除。...连续性 插入成功时,其数据的 ID 和前一次插入成功时数据的 ID 相邻。 自增主键的单调性 为何会有单调性的问题? 这主要跟自增主键最大值的获取方式,以及存放位置有关系。...如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。 自增主键最大值怎么取的?存放到哪里?...批量插入中的一部分的 ID 是指定的(非 0 且非 NULL),另一部分未指定,使用数据库生成的自增 ID。...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的自增 ID。

    10.8K10

    【JavaScript】JavaScript 运算符 ② ( 表达式 与 返回值 | 自增 与 自减运算符 细节 | 前置自增运算符 | 后置自增运算符 )

    , 需要将 接收结果的变量 写在 赋值运算符的左边 , 表达式写在 赋值运算符 的右边 ; 如 : var num = 1 + 2 , 表达式 1 + 2 赋值给 num 变量 ; 2、自增 与 自减运算符...细节 在 " 算术运算符 " 中有 自增运算符 ++ 自减运算符 -- 这两个运算符 在 JavaScript 开发中 , 使用的非常频繁 ; 自增 和 自减 运算符 必须与 变量 一起使用 , 不能与...和 自减 运算符 , 可以放在 变量 的前面 ++num , 这是 前置自增运算符 ++num ; 也可以放在 变量的后面 num++ , 这是 后置自增运算符 num++ ; 前置自增运算符 ++num...= num - 1 ; 前置自增运算符 运算时 , 先进行 自增 / 自减 , 然后 再 返回表达式的值 ; ( 这于 后置 自增 / 自减 运算符 正好相反 , 后置运算符 先 返回表达式值 然后再...如果写在表达式中 , 则其效果不同 ; 后置自增运算符 运算时 , 先返回表达式的值 , 然后 再 进行 自增 / 自减 ; ( 这于 前置 自增 / 自减 运算符 正好相反 , 前置运算符 先 自增

    9110

    mysql主键自增策略_MySQL 自增主键机制

    大家好,又见面了,我是你们的朋友全栈君。 自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪?...自增值修改发生在插入数据的操作之前,如果插入失败,自增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4....一次性insert多条记录时,如果能计算出需要多少个id,就一次性申请,申请完就释放; c. insert … select 默认会使用语句级的锁,只有语句执行完才会释放自增锁,为了数据的一致性; d....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 的策略(注:该策略是导致自增 id 不连续的第三种原因...id,每次申请到的自增 id 个数都是上一次的两倍。

    9.5K50
    领券