重新理解自增表达式
来源:互联网 发布:网络信息安全模型 编辑:程序博客网 时间:2024/05/17 22:00
var j = 0;for(var i=0;i<100;i++){ j = j++;}console.log(j);
今天偶然遇到了这样的一个问题,求j的最终值等于多少。我的第一反应就是j=100,答案真的是100吗?错误。
按照我的理解,在第一次循环里面,j=j++;右边的j先赋值给左边的j,此时j为0。赋值完毕后,j再自增1,此时j应该为1。以此类推100次循环后j为100。可我为什么在控制台打印出来j最终等于0呢。
我怀疑理解了这么久的自增是不是理解错了。于是查阅相关资料,发现自增原来是这样的。
就拿第一次循环来举例吧,j=j++;先新建一个临时变量,如temp,把右边j的值给temp,此时temp为0;然后右边的j自增,此时的j变为1;j++是一个表达式,是有返回值的,返回值就是temp,最终把temp返回给左边的j,所以第一次循环j最终为0,以此类推,不管循环多少次,j永远为0。
把此过程写成一个方法更好理解:
function makeAdd(args){ var temp = args; args = args+1; return temp;}
因此j=j++可以看做:
j = makeAdd(j);
当然,上述的方法仅仅是方便理解,在实际中是行不通的。因为在js里面基本类型是按值传递的(需详细了解可以看我上一篇博客),需要写成按引用传递的对象。
var obj = {}; obj.x = 0; var makeAdd = function (o) { var temp = o.x; o.x = o.x + 1; return temp; }; for (var i = 0; i < 100; i++) { obj.x = makeAdd(obj); } console.log(obj.x);
0 0
- 重新理解自增表达式
- 逗号表达式,自增
- mysql 自增主键重新排序
- Access自增列重新清空
- 自增自减、关系表达式
- 自增运算符表达式
- /*自增运算测试*/ 理解
- DB2 重新设定表自增字段的当前值
- ID自增列重新从1开始算起
- Mysql自增主键ID调整|重新排序
- SQL数据库表自增列重新排列
- PostgreSQL让自增字段重新从1开始
- Mysql自增主键ID调整|重新排序
- SQL ID自增列从1开始重新排序
- Mysql自增主键ID调整|重新排序
- 删除数据表,重新定位自增的字段
- Mysql自增id重新从1排序
- Mysql对自增主键ID进行重新排序
- emacs 插件列表
- 忙里偷闲 教你如何通过修改android内核实现root
- crt添加循环发送命令
- img标签在jsp页面无法显示时该怎么办
- 一行python能做什么!
- 重新理解自增表达式
- 防盗链技术
- Shader学习笔记(六)_Time的使用,会动的纹理
- C#中将DataTable中数据导出到csv文件中
- Android编译详解之lunch命令
- 安徽大学线性代数习题册(第三章详细解答)
- getView方法中产生NullPointerException异常
- ERROR The requested URL could not be retrieved
- Log图文详解(Log.v,Log.d,Log.i,Log.w,Log.e)的用法