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
随机推荐
- python27期尚哥讲TCP:
TCP:传输控制协议(使用情况多于udp) 稳定:保证数据一定能收到 相对UDP会慢一点 web服务器一般都使用TCP(银行转账,稳定比快要重要)TCP通信模型: 在通信之前,必须先等待建立链接 TC ...
- 浅谈字符串Hash
浅谈字符串Hash 本篇随笔讲解Hash(散列表)的一个重要应用:字符串Hash. 关于Hash Hash是一种数据结构,叫做Hash表(哈希表),也叫散列表.关于Hash的实现,其实与离散化颇为类似 ...
- luoguP4097 [HEOI2013]Segment
题意 李超树板子题. 对每个区间维护该区间中点\(mid\)的最优线段. 插入一个线段: 求出这个线段的斜率和截距,注意特判无斜率的情况,得到\(y=kx+b\). 之后开始在线段树上插入,假设当前节 ...
- ES6 Set求两个数组的并集、交集、差集;以及对数组去重
并集: const arr1 = [1, 2, 3, 2, 5]; const arr2 = [1, 4, 6, 8, 3]; // 将两个数组合并 const concatArr = [...arr ...
- 2019 SDN阅读作业(2)
1.过去20年中可编程网络的发展可以分为几个阶段?每个阶段的贡献是什么? 可编程网络的发展可以分为以下三个阶段: (1)主动网络(Active networking,20世纪90年代中期到21世纪初) ...
- linux字体,bashrc的问题的解决
0.查看文件 :set ff #查看文件类型 这里是fileformat=unix :set ff=dos 设置为dos模式, 也可以用 sed -i 's/$/\r/' :set ff=unix 设 ...
- matlab练习程序(贝塞尔曲线)
下面三个公式分别是一次.二次和三次贝塞尔曲线公式: 通用的贝塞尔曲线公式如下: 可以看出,系数是由一个杨辉三角组成的. 这里的一次或者二次三次由控制点个数来决定,次数等于控制点个数-1. 实现的效果如 ...
- Harbor + Https 部署
关闭防火墙和selinux systemctl stop firewalld sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/sysconfig/selin ...
- 树莓派4B 更新wiringPi库到2.52的方法的wiringPi库2.5.2版本wiringpi-latest.deb下载
树莓派4B 更新wiringPi库到2.52的方法 – 树莓派中文站 http://www.52pi.net/archives/1918 通过如上链接可知,需要通过如下命令下载wiringpi-lat ...
- Chrome教程之使用Chrome DevTools命令菜单运行命令
1.模拟移动设备 点击 Toggle Device Toolbar 2.限制网络流量和 CPU 占用率 要限制网络流量和 CPU 占用率,请从 Throttle 列表中选择 Mid-tier mobi ...