首页
学习
活动
专区
工具
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

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=

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

    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语言类似。

    6883230

    EasyC++20,C++中

    这是EasyC++系列第20篇,简单聊聊C++当中减。 减 基本用法 减是C++当中两个使用频率非常高运算符,不仅在循环当中用到,在日常代码当中也经常使用。...甚至C++这个名称由来都和运算符有关,表示C语言升级版。当然这也是C#名字由来,#这个符号表示4个叠加加号……不得不吐槽这微软恶趣味。...我们都知道有两种写法,一种是i++另外一种是++i。这两种写法对于i这个变量最终结果来说是一样,都是了1,但是对于这个操作发生时间,则有很大差异。...对此,C++当中有一个叫做顺序点概念,顺序点指的是程序执行过程中一个点。在C++当中语句中分号就是一个顺序点,在程序处理下一条语句之前,赋值运算符、减运算符执行所有修改都必须完成。...意味着我们在执行cout之前,cnt变量就已经完成了。这进一步说明了while(cnt++ < 10)本身就已经是一个完整表达式了。因此在这个表达式执行之前,C++就会完成操作。

    66130

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

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

    75820

    C 语言负数移位运算讲解

    大家好,又见面了,我是你们朋友全栈君。 C 语言负数移位运算讲解 “>”为移位运算符。 “<<”为左移位运算符,即数据字节中每个二进制位同时 向左移位。...如“x>”为右移位运算 符,即数据字节中每个二进制位同时向右移位。...如“x>>n”表示 x 中每个二进制位同时 向右移动 n 位。...总结:负数左移时,任何情况下“移入”位将用“0”补齐。 “>>”右移位运算可分为两种情况:一种是移入“0”叫逻辑右移;一种是移入“1”叫 算术右移。 负数右移用到是算术右移。...总结:负数右移时,任何情况下“移入”位将用“1”补齐。 注:二进制表最左端二进制位表示符号位,“+”用“0”表示,“-”用“1”表示。

    2.4K30

    C++ 减运算符重载和性能分析

    — 1 — 重载形式 运算符和减运算符是有「前置」和「后置」之分,如: a++ // 后置运算符 ++a // 前置运算符 b-- // 后置减运算符 --b // 前置减运算符...为了区分所重载是「前置」运算符还是「后置」运算符,C++规定: 「前置」运算符作为一元运算符重载,重载为成员函数形式如下: // 前置运算符重载函数,函数参数是空 T & operator+...那么问题来了: 为什么「前置」运算符返回是引用 & ? 为什么「后置」运算符返回是普通对象(临时对象)? 主要是因为为了保持原本 C++ 前置和后置运算符特性。...「后置」减运算符重载,就有点不同,例如后置++,是先参与运算,再进行,所以返回值是没对象,具体实现如下: ?...---- — 4 — 性能比较 从上面的例子,我们看到「后置」运算符重载函数执行步骤: 先要产生一个临时对象来保存未减前对象; 接着成员变量减; 最后返回修改前对象(临时对象);

    1.1K20

    sizeof遇到问题

    1.导言 本来是在C++群里回答一个很简单类型转换后判断字节问题,后来发现代码中有个点还蛮有意思,所以记录下来 2.场景 有这个代码 int a = 5; sizeof(a++); cout <<...a << endl; 我发现a竟然输出5,来想后不是变成6吗 这是因为 sizeof 是一个编译时运算符,它不会对其操作数进行求值。...在这个例子中,sizeof(a++) 只会返回变量 a 大小,而不会执行 a++ 这个操作。所以,当输出 a 值时,它仍然是初始值 5。...编译器会根据操作数类型来确定 sizeof 结果,而不是根据操作数值。因此,即使操作数是一个表达式,sizeof 也不会对它进行求值。...也可以理解为sizeof里面如果有等号的话,等号右边东西都是没用

    8910

    MySQL探究

    2.5 锁MySQL锁是指在使用主键(Auto Increment)时,为了保证唯一性和正确性,系统会对字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一增值。...:为一些(但不是全部)新行指定自动增量值2.5.2 锁原理1)插入原理MySQL实现机制是使用了一个名为"auto-increment lock"互斥锁。...锁确保了插入记录唯一性和正确性,避免了并发插入产生冲突。但同时也会带来一些性能上影响,因为并发插入操作需要等待锁释放。因此,在高并发场景下,可能需要考虑使用其他方案来避免锁成为瓶颈。...Tips:锁跟事务无关,即使多个insert语句存在同一个事务中,每次insert都会申请最新锁来获取最新AUTO_INCREMENT值;获取到增值后释放,而不是事务结束释放;2)锁表锁需要注意是...这也是InnoDB默认值;Simple inserts:InnoDB能够预先知道要插入行数,因此产生锁只会锁住对应那些id(页锁),避免表级别的锁Bulk Inserts:InnoDB无法预知要插入

    11721

    MongoDB id 生成

    概述 我们使用 MySQL 等关系型数据库时,主键都是设置成。 但在分布式环境下,尤其是在分库分表以后,单纯主键会产生冲突,需要考虑如何生成唯一 ID。...缺点 虽然在同一个进程内一秒内生成多个主键 id 是,但是在数据库全局是没有这样规律。 有时,能够完全 id 对于应用业务来说是非常重要。...MongoDB 允许我们自己生成 _id,但是这样唯一性压力就又来了,在并发环境下保证 ID 严格与避免 ID 冲突有时是需要丰富经验。 5....自己生成 id — findAndModify 虽然已经有很多生成 id 方案可供选用,如依赖 redis 等,但 MongoDB 本身提供了原子操作,我们可以通过 MongoDB 提供原子操作来实现...id

    8K30

    C语言负数做运算你会了吗

    ("结果6: %d\n", a/c); return 0; } 昨天在公司帮一个小同事在查找问题,同事描述在做一个简单功能是输入一组数据做算数运算,包括加减乘除。...发现在输入负数时结果会出问题,这么一来大概就知道问题出在什么地方了。 先来看一下上面示例代码输出结果,有没有和你想一样?...C语言负数取余取整规则 我们先来考虑一下,为什么上面示例代码在取余和取整时符号不同呢,这就涉及到C语言负数参与除法时符号问题。...C 语言负数做除法时候,商是令其与分母相乘绝对值不超过分子绝对值且最接近那个数。...取余时,余数与被除数(即分子符号)相同 取整时,先将各个带符号数全部取正值再做除法,再根据负号个数确定商符号 总结 这个问题在C语言中看似简单,但是往往不注意也可能会引起大问题。

    2K40

    python 运算符

    python 运算符 博客分类: python python 这段code: Python代码 >>> i =1 >>> ++i >>> print i 1 很坑爹是吧,python...python 不使用 ++ 哲学逻辑:编译解析上简洁与语言本身简洁,就不具体翻译了 Python代码 >>> b = 5 >>> a = 5 >>> id(a) 162334512 >>> id...(b) 162334512 >>> a is b True 可以看出, python 中,变量是以内容为基准而不是像 c 中以变量名为基准,所以只要你数字内容是5,不管你起什么名字,这个变量 ID...是相同,同时也就说明了 python 中一个变量可以以多个名称访问 这样设计逻辑决定了 python 中数字类型值是不可变,因为如果如上例,a 和 b 都是 5,当你改变了 a 时,b 也会跟着变...,这当然不是我们希望 因此,正确操作应该 a = a + 1 或者 a += 1,当此 a 后,通过 id() 观察可知,id 值变化了,即 a 已经是新值名称

    8.2K10

    Greenplum和Postgresql主键

    参考:https://blog.csdn.net/u011042248/article/details/49422305 1、第一种情况就是创建数据表时候创建主键,由于业务需要自己数据表已经创建了...由于Greenplum是从Postgresql发展而来,由于postgreSQL主键需要使用序列,所以Greenplum主键也需要使用序列。...使用SERIAL方式创建ID主键,需要注意是Greenplum和Postgresql区分大小写,所以注意加上双引号。 1 DROP TABLE IF EXISTS "core_data"."...红色箭头所指其他,下拉以后可以看到序列,然后点击序列,可以查看自己创建序列。由于是正式项目,所以不截图了。 ? 可以查看详细信息: ? 2、第二种方式是,先创建序列,然后设置字段。...START WITH 100 3 INCREMENT BY 1 4 NO MINVALUE 5 NO MAXVALUE 6 CACHE 1; 然后使用下面的alter table语句就可以将自己表设置主键

    2.1K20
    领券