i++和++1
概述:
i++和++i 这个问题困扰了我很长时间,在这段时间里自己不止一次的怀疑自己的智商,难道自己对编程一点天赋都没有吗?此问题严重打击了我的自信心.......
也曾苦苦暗自琢磨,也曾百度谷歌疯狂搜索,得到答案都是一样的:“i++是先赋值,后运算;而++1是先运算,后赋值”,谁给谁赋值?谁和谁运算?越看越蒙。
直到今天,终于在一位老师的点拨下搞明白了。
我们要从两个不同的角度等待这个问题,第一个角度我称为“自己给自己玩”,第二个角度我称为“自己陪别人玩”
第一个角度:“自己给自己玩-------都是a=a+1的意思”
无论是i++还是++i,都是都是在原本的数值上加一的意思,如下面的两个例子:
[root@www ~]# i=2
[root@www ~]# let i++
#如上,上面的i++就相当于i=i+1,第一个i在没运算之前是没有值的,第二个i就是代表上面的2;在运算之后的结果就变成了i=3(2+1)了,所以下面的echo $i的值就是3
[root@www ~]# echo $i
3
---------------------------------------我是第一个角度下,i++和++i的分隔线---------------------------------------
[root@www ~]# i=3
[root@www ~]# let ++i
#如上,上面的++i也相当于i=i+1,第一个i在没运算之前是没有值的,第二个i就是代表上面的3;在运算之后的结果就变成了i=4(3+1)了,所以下面的echo $i的值就是4
[root@www ~]# echo $i
4
小结:
在第一个角度下,都是先赋值,再运算。也就是说先给第二个i赋值,然后进行运算,最后得出第一个i的值。
第二个角度:“自己陪别人玩---没那么简单,有了分别心,分别了先后”
这里的先后指的赋值和运算的先后,那么谁给谁赋值?谁为谁运算?先别急,慢慢来。
我们先要理解“自己给自己玩”是什么意思?所谓的自己给自己玩,就是自己拿自己“开刀”,在自己的基础上加加减减,对别人(别的变量)没有什么影响。就像i++和++i,都是围绕着$i,自己围绕着自己也翻不起什么风浪,不管是i++还是++i全是i=i+1的意思,并且在运算之前第一个i没有值,而第二个i是有值的,运算之后第一个i才是有值的。
而自己陪别人玩的意思就是通过自己给别的变量赋值,这样就没有那么简单了!
给别人赋值时,如果用i++的话,就得先把i原本的值赋给别人,然后再自己给自己运算,举个粟子:
[root@www ~]# i=2
[root@www ~]# let x=i++ # 变量i现在给变量x赋值,过程是这样的,i要先把自己的值(也就是2)赋给x,i原本是2,赋给x之后,x就变成了2,所以当你echo $x的时候就是2,不信你就看下一行!好,继续,x现在有值了,就先把x放一边,剩下的就是i++了,i++就是i=i+1的意思,就又回到了“自己给自己玩”,这样i就等于3了,不信你看下下行!
[root@www ~]# echo $x
2
[root@www ~]# echo $i
3
总结:i++先稳住别的变量,先给别的变量赋值,然后再自己给自己玩。
---------------------------------------我是第二个角度下,i++和++i的分隔线---------------------------------------
给别人赋值时,如果用++i的话,就得自己先给自己运算,然后把运算后的结果赋给别的变量,举个粟子
[root@www ~]# i=2
[root@www ~]# let x=++i #先是“自己给自己玩”,x在没有运算之前是没有值的,只有i有值(2),先看++i,我们可以得到i=3,而x在i运算之后就等于i的值,所以也等于3。
[root@www ~]# echo $x
3
3[root@www ~]# echo $i
3
随机推荐
- web-神盾局的秘密
题目地址 http://web.jarvisoj.com:32768/ 首页是一张图片 查看源码,看到了一些猫腻,showing.php c2hpZWxkLmpwZw==是base64编码 ...
- 古来月小队 Alpha冲刺阶段博客目录
一.Scrum Meeting 第六周: 链接:https://www.cnblogs.com/ouc-xxxxxx/p/11789325.html 任务:搭建安卓编程环境,学习安卓前端知识 第七周: ...
- (day54)六、事务、分组、F、Q、常用字段、事务
目录 一.聚合查询aggregate 二.分组查询annotate 三.F与Q查询 (一)F查询 1. 查询库存数大于卖出数的书籍 2. 将所有书的价格上涨100块 3.将所有书的名称后面全部加上 & ...
- luoguP4151 [WC2011]最大XOR和路径
题意 这题有点神啊. 首先考虑注意这句话: 路径可以重复经过某些点或边,当一条边在路径中出现了多次时,其权值在计算 XOR 和时也要被计算相应多的次数 也就是说如果出现下面的情况: 我们可以通过异或上 ...
- Paper | Noise2Noise: Learning Image Restoration without Clean Data
目录 故事背景 算法原理 点估计 神经网络算法与点估计的关系 核心思想 回头品味 实验 高斯 其他生成噪声 发表在2018 ICML. 摘要 We apply basic statistical re ...
- 【08月20日】A股滚动市净率PB历史新低排名
2010年01月01日 到 2019年08月20日 之间,滚动市净率历史新低排名. 上市三年以上的公司,2019年08月20日市净率在30以下的公司. 来源:A股滚动市净率(PB)历史新低排名. 1 ...
- Python连载18-closure闭包解释及其注意点
一.闭包 1.定义:当一个函数在内部定义函数,并且内部的函数应用外部函数的参数或者局部变量,当内部函数被当做返回值的时候,相关参数和变量保存在返回的函数之中,这种结果,叫做闭包. 2.例子:连载17中 ...
- 详解 IaaS、PaaS和SaaS 以及他们各自的代表公司
——IaaS,PaaS和SaaS 是云计算领域的专业术语,也是云计算的三种服务模式. (1)SaaS:Software as a Service,软件即服务(也称为云应用程序服务) . 云市场中企 ...
- 十一、Spring之事件监听
Spring之事件监听 ApplicationListener ApplicationListener是Spring事件机制的一部分,与抽象类ApplicationEvent类配合来完成Applica ...
- Python之np.random.permutation()函数的使用
官网的解释是:Randomly permute a sequence, or return a permuted range. 即随机排列序列,或返回随机范围.我的理解就是返回一个乱序的序列.下面通过 ...