a++与++a的陷阱与盲区
故事发生在2019.7.15的3.pm,正在复习数据结构题目,写了一句如下指令(以下函数运行在win10的dev编译器下面)
#include<bits/stdc++.h>
using namespace std; int main(void){
int a = 0;
printf("%d\n", a++);
// printf("%d%d\n", a++, ++a);
return 0;
}
发现2条语句输出不一样,你敢信?前面输出0,后面输出1,2,心态瞬间就崩了,同为a++,2次结果输出不一样!!!随后找了晗神和谢大佬,2位大佬给出的答案不一样
晗神(centos的g++运行环境):前面是0,后面是0,1 ( 和我一样,当场崩溃,怀疑是编译器原因)
谢大佬:不同编译器结果不同!!!(顿悟为什么晗神和自己输出结果不一样)
--------------------------------------------------------------- ------------------------------------------------------------------
----------------------------------------个人建议:后面内容没必深入了解,只要注意别将a++,a--,--a,++a一起输出就好 ------------------------
-------------------------------------------------------------------------------------------------
但是为什么我会输出1,2呢?
汇编语言解释一下(以i++,--i为例)
这三句汇编中执行了–操作,说明,printf函数中,两个i,先计算–i,然后计算i++,然后计算--i.
这三句话做了一下的事情:
1.将i从内存中取出来,然后存入到寄存器中。
2.将寄存器中的值-1。
3.将寄存器中减过1得值存入到内存地址中去。
总结:前置减减,是对值做了减操作后,将其存入到原来的位置。
简单来说:就是先-i,然后计算i++,再算--i, 也就是说(i = 0,结果会输出-1, 0)
全部列出来:
#include<bits/stdc++.h>
using namespace std; int main(void){
int a = 0;
// printf("%d\n", a++); //输出0
// printf("%d%d\n", a++, ++a); //输出1 2
// printf("%d%d\n", a++, a++); //输出1 0 ---
// printf("%d%d\n", a++, --a); //输出-1 0
// printf("%d%d\n", a++, a--); //输出-1 0
// printf("%d%d\n", ++a, ++a); //输出2 2
// printf("%d%d\n", ++a, a++); //输出2 0 ---
// printf("%d%d\n", ++a, --a); //输出0 0
// printf("%d%d\n", ++a, a--); //输出0 0 return 0;
}
但是a++, a++ 与 ++a,a++输出结果不符合道理,然后看下面这篇博客
https://blog.csdn.net/findgeneralgirl/article/details/78376834
总结了一句话:猜测:a++放的是临时变量,++a是直接计算,
假设a = 0
也就是说a++,a++这样,先将a++压栈,临时变量a + 1,然后输出a++(输出1),但是临时变量不影响后面a++的值,所以 a++依然是0
而对于a++,++a这样,先压栈,临时变量a + 1,然后输出a++(输出1),临时变量影响++a的值,所以++a是2
后面运算--a,a++,--a,a--之类的也满足上面的观点
由于不同编译器运行结果不一样,所以没事最好别把a++,++a写到一条语句里面
拓展(湖南大学2012年研究生入学真题):
1.a = 2,b = 3, b+=(++a)+(++a)
分析:b += 优先级最低,最后面算,先拆2个括号a = 4,b += (4 + 4) ,b = 11
2.i = 5, i+++i
分析: ++优先级比+高,所以i = 6即(i++) + i = 5 + 6 = 11,若改成(++i) + i = 6 + 6 = 12
a++与++a的陷阱与盲区的更多相关文章
- 你可能不知道的陷阱, IEnumerable接口
1. IEnumerable 与 IEnumerator IEnumerable枚举器接口的重要性,说一万句话都不过分.几乎所有集合都实现了这个接口,Linq的核心也依赖于这个万能的接口.C语言的 ...
- java笔记--笔试中极容易出错的表达式的陷阱
我相信每一个学过java的人儿们都被java表达式虐过,各种"肯定是它,我不可能错!",然后各种"尼玛,真假,怎么可能?",虽然在实际开发中很少会真的让你去使用 ...
- 【Swift】iOS UICollectionView 计算 Cell 大小的陷阱
前言 API 不熟悉导致的问题,想当然的去理解果然会出问题,这里记录一下 UICollectionView 使用问题. 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cn ...
- JavaScript中的this陷阱的最全收集
JavaScript来自一门健全的语言,所以你可能觉得JavaScript中的this和其他面向对象的语言如java的this一样,是指存储在实例属性中的值.事实并非如此,在JavaScript中,最 ...
- 高性能MySQL(四):schema陷阱
一.schema陷阱 二.缓存表和汇总表 三.范式和反范式
- C#_闭包陷阱
如果匿名方法(Lambda表达式)引用了某个局部变量,编译器就会自动将该引用提升到该闭包对象中. 即将for循环中的变量i修改成了引用闭包对象的公共变量i.这样一来,即使代码执行后离开了原局部变量i的 ...
- 安装 Linux 时碰到的硬盘分区的陷阱及应对
硬盘分区的陷阱及应对 之所以想到写这篇,是因为本人在折腾 Linux 系统的过程中,有多次掉入硬盘分区的陷阱的经历.最近几天,再一次掉入坑中,折腾了两天才从坑中爬出来.经过多方查询资料,终于弄明白了硬 ...
- NULL的陷阱:Merge
NULL表示unknown,不确定值,所以任何值(包括null值)和NULL值比较都是不可知的,在on子句,where子句,Merge或case的when子句中,任何值和null比较的结果都是fals ...
- 洛谷P1156 垃圾陷阱[背包DP]
题目描述 卡门――农夫约翰极其珍视的一条Holsteins奶牛――已经落了到“垃圾井”中.“垃圾井”是农夫们扔垃圾的地方,它的深度为D(2<=D<=100)英尺. 卡门想把垃圾堆起来,等到 ...
随机推荐
- day25-网络基础
# 一.子网掩码: # 1. 作用是划分子网,就是将某个ip地址划分成网络地址和主机地址两部分. # 形式上等同于ip地址,也是一个32位二进制数, # 如果它的网络部分(前24位)全为1,主机部分( ...
- k8s中command、args和dockerfile中的entrypoint、cmd之间的关系
当用户同时写了command和args的时候自然是可以覆盖DockerFile中ENTRYPOINT的命令行和参数,那么对于具体情况呢,比如仅仅写了command或者args的时候呢?完整的情况分类如 ...
- python语法基础-文件操作-长期维护
############### python-简单的文件操作 ############### # python中文件的操作 # 文件操作的基本套路 # 1,打开文件,默认是是只读方式打开文件 ...
- nutzboot 项目打包排除或指定配置文件(夹)
springboot 是一样的 我这里就是从springboot哪里拿过来的 (nutzboot2.x已测试可以使用) 排除指定文件 在pom 文件 build 标签内添加 resources < ...
- AI动作捕捉技术,会让制造业大幅度降低成本吗?
现代动作捕捉系统应该是起源于100多年前的动画工业,通过一种叫做"动态遮罩或影像描摹"的技术,动画师们可以获得流畅的.栩栩如生的动作:后来到了20世纪80年代,动画师们设计出带有活 ...
- 二:MySQL的操作
1:创建数据库 create database bjpowernode ; 2:使用数据库 use bjpowernode; 3:导入数据库文件sql source 然后把SQL文件拖过来就可以了 ...
- python语法基础-面向对象-进阶-长期维护
############### @property定义属性 ############## # 所以对于定义属性你有好几种方式了和种类了,# 静态属性,动态属性, # property # ...
- [LC] 287. Find the Duplicate Number
Given an array nums containing n + 1 integers where each integer is between 1 and n (inclusive), pro ...
- [LC] 136. Single Number
Given a non-empty array of integers, every element appears twice except for one. Find that single on ...
- OpenWrt Web 开发 LuCI框架 lua语言
LuCI作为“FFLuCI”诞生于2008年3月份,目的是为OpenWrt固件从 Whiterussian 到 Kamikaze实现快速配置接口.Lua是一个小巧的脚本语言,很容易嵌入其它语言.轻量级 ...