Javascript数组中push方法用法分析


Posted in Javascript onOctober 31, 2016

本文实例讲述了Javascript数组中push方法用法。分享给大家供大家参考,具体如下:

看下面代码:

var o = {
  1:'a'
  ,2:'b'
  ,length:2
  ,push:Array.prototype.push
};
o.push('c');

Q:o现在内部的值是什么样子?

我的第一反应是排斥,为什么要研究不合理情况下【解释引擎】的行为?但是这种推论有时候又很吸引人,于是我回来的时候仔细思考了下,发现其实很简单。

对于push这个方法,我条件反射地想到的就是栈,【数据结构的经典栈】中压栈和弹栈操作依据的都是栈顶指针,栈顶指针始终指向栈顶,意味着它会因为压弹栈而自动增减。在javascript中的数组中这个指针就是length。所以在上面的代码中,o.push('c')就是o.2 = 'c'(当然o.2不能直接访问,这只是伪代码),所以代码执行完o中数据如下:

{
  1:'a'
  ,2:'c'
  ,length:3 //push操作=>length+1
  ,push:Array.prototype.push
}

补充说明:

JavaScript中,万物皆对象,而javascript的对象与强类型的对象有一些不同的地方,可以理解成就是一组键值对的集合。其array类型也不例外,它的下标访问就是键访问(不过它的键都是自然数),在上面的例子中赋值给a的对象字面量实际模拟了一个数组(一个下标从1开始的数组)——当然只有部分数组的特性,比如真实的数组在进行键访问的时候,会根据length进行越界检查。

只要知道push的位置依据的是length就可以了,下面种种看似奇怪的现象都好理解:

//1.length不存在,引擎置为0
var o = {
  '1':'a'
  ,'2':'b'
  ,push:Array.prototype.push
};
o.push('c');//c {0:'c',1:'a',2:'b',...}
//2.length为负值,这是个有趣的问题,涉及到原码反码和补码【1】
var o = {
  '1':'a'
  ,'2':'b'
  ,length:-1
  ,push:Array.prototype.push
};
o.push('c');//c {1:'a',2:'b',4294967295:'c',length:4294967296,...}
//3.length为字符或对象
var o = {
  1:'a'
  ,2:'b'
  ,length:'A'
  ,push:Array.prototype.push
};
o.push('c');//c {0:'c',1:'a',2:'b',length:1,...}我还以为js解释器会把A转换成ASCII码来给length赋值呢,终于看到了javascript的自由还是有节操的

计算机中数值都是以补码方式存储的,为了方便运算,-1的补码与4294967295补码一样,根据length的语义,此处是无符号数

[-1]补 = 1111 1111 1111 1111 1111 1111 1111 1111 =  [4294967295]补  = 1111 1111 1111 1111 1111 1111 1111 1111

所以这样我们接差对2中的o压入一个对象,key取的是4294967296,但是数组的最大长度限制为4294967296,也就是说下标只能取到4294967295,只会取到32位——对于4294967296 = 1 0000 0000 0000 0000 0000 0000 0000 0000 取后32位,就变成了0,所以此次push的位置是0。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
5 cool javascript apps
Mar 24 Javascript
浅谈js中变量初始化
Feb 03 Javascript
jQuery选择器源码解读(七):elementMatcher函数
Mar 31 Javascript
JQuery实现图片轮播效果
Sep 15 Javascript
使用jquery提交form表单并自定义action的方法
May 25 Javascript
jQuery简单实现title提示效果示例
Aug 01 Javascript
easyUI实现(alert)提示框自动关闭的实例代码
Nov 07 Javascript
Vue.js使用v-show和v-if的注意事项
Dec 13 Javascript
el表达式 写入bootstrap表格数据页面的实例代码
Jan 11 Javascript
完美解决linux下node.js全局模块找不到的情况
May 16 Javascript
详解微信小程序支付流程与梳理
Jul 16 Javascript
vue中封装axios并实现api接口的统一管理
Dec 25 Vue.js
JavaScript中的await/async的作用和用法
Oct 31 #Javascript
使用 jQuery.ajax 上传带文件的表单遇到的问题
Oct 31 #Javascript
微信小程序 开发工具快捷键整理
Oct 31 #Javascript
微信小程序 实现tabs选项卡效果实例代码
Oct 31 #Javascript
HTML5基于Tomcat 7.0实现WebSocket连接并实现简单的实时聊天
Oct 31 #Javascript
jQuery绑定事件的四种方式介绍
Oct 31 #Javascript
JS 实现导航菜单中的二级下拉菜单的几种方式
Oct 31 #Javascript
You might like
php的curl实现get和post的代码
2008/08/23 PHP
php过滤敏感词的示例
2014/03/31 PHP
php版微信自定义回复功能示例
2016/12/05 PHP
yii框架搜索分页modle写法
2016/12/19 PHP
PHP调用QQ互联接口实现QQ登录网站功能示例
2019/10/24 PHP
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
2007/04/20 Javascript
jQuery基本选择器选择元素使用介绍
2013/04/18 Javascript
浅析用prototype定义自己的方法
2013/11/14 Javascript
使用JS实现jQuery的addClass, removeClass, hasClass函数功能
2014/10/31 Javascript
7个让JavaScript变得更好的注意事项
2015/01/28 Javascript
javascript拖拽效果延伸学习
2016/04/04 Javascript
JS实现数字格式千分位相互转换方法
2016/08/01 Javascript
Bootstrap 网站实例之单页营销网站
2016/10/20 Javascript
JavaScript数组_动力节点Java学院整理
2017/06/26 Javascript
vue click.stop阻止点击事件继续传播的方法
2018/09/04 Javascript
vue结合element-ui使用示例
2019/01/24 Javascript
Vue 动态路由的实现及 Springsecurity 按钮级别的权限控制
2019/09/05 Javascript
Python入门之后再看点什么好?
2018/03/05 Python
python,Django实现的淘宝客登录功能示例
2019/06/12 Python
Python基于yield遍历多个可迭代对象
2020/03/12 Python
Python实现Word表格转成Excel表格的示例代码
2020/04/16 Python
Python图像阈值化处理及算法比对实例解析
2020/06/19 Python
美国珠宝店:Helzberg Diamonds
2018/10/24 全球购物
通往英国高街的商店橱窗:Down Your High Street
2020/07/19 全球购物
几个Linux面试题笔试题
2012/12/01 面试题
数控专业大学生的自我鉴定
2013/11/13 职场文书
心得体会怎么写
2013/12/30 职场文书
优秀幼教自荐信
2014/02/03 职场文书
文秘档案管理岗位职责
2014/03/06 职场文书
食品工程专业求职信
2014/06/15 职场文书
2014年最新学校运动会广播稿
2014/09/17 职场文书
2015年度销售个人工作总结
2015/03/31 职场文书
植树节新闻稿
2015/07/17 职场文书
Python 用户输入和while循环的操作
2021/05/23 Python
python单元测试之pytest的使用
2021/06/07 Python
MySQL解决Navicat设置默认字符串时的报错问题
2022/06/16 MySQL