javascript也支持关联数组?与对象相比是不是存取效率更高?

php中文网
发布: 2016-06-06 20:40:14
原创
1390人浏览过

如题,原来一直误以为js里面不能像php那样定义关联数组,如a["color"]=red;
但是前几天偶然发现可以。
想请教一下这样的定义方式与操作对象相比是不是更高效?两者的后台实现方式是不是不一致呢?

//定义对象
obj={color:"red",name:"apple"};
//关联数组
arr=[];
arr["color"]="red";arr["name"]="apple";
obj=[];obj.push(arr);

回复内容:

如题,原来一直误以为js里面不能像php那样定义关联数组,如a["color"]=red;
但是前几天偶然发现可以。
想请教一下这样的定义方式与操作对象相比是不是更高效?两者的后台实现方式是不是不一致呢?

//定义对象
obj={color:"red",name:"apple"};
//关联数组
arr=[];
arr["color"]="red";arr["name"]="apple";
obj=[];obj.push(arr);

javascript 的數組也是對象,同時任何對象也可以像數組一樣使用,細節如下。

javascript也支持关联数组?与对象相比是不是存取效率更高?

參見:http://jayconrod.com/posts/52/a-tour-of-v8-object-representation

詳細講解了 V8 的對象實現。

對象的實現分爲兩層:

而模式有 array mode 和 dictionary mode。一般情況會用 array mode,有時也會降級。

Named properties

in-object properties 使用公共 map 來描述其結構,某些情況(難以共用 map)會降級爲 Dictionary mode。

V8 can handle minor divergences like this just fine, but if your code assigns all sorts of random properties to objects from the same constructor in no particular order, or if you delete properties, V8 will drop the object into dictionary mode, where properties are stored in a hash table. This prevents an absurd number of maps from being allocated.

一個叫做 In-object slack tracking 的過程用來決定對象的大小,其後的屬性作爲 extra properties 使用單獨的數組儲存。

Now I'm sure your next question is, "what happens when a new property is added after in-object slack tracking is complete?" This is handled by allocating an overflow array to store the extra properties. The overflow array can always be reallocated with a larger size as new properties are added.

Numbered properties

其中,fast elements 包括

Fotor AI Image Upscaler
Fotor AI Image Upscaler

Fotor推出的AI图片放大工具

Fotor AI Image Upscaler 73
查看详情 Fotor AI Image Upscaler

fast small integers
fast doubles
fast values

然而 fast elements 有時也會降級爲 dictionary mode

If you assign to an index that's way past the end of your the elements array, V8 may downgrade the elements to dictionary mode.

當然由於分開儲存,降級並不會影響到其它類型的屬性。

Because named properties and elements are stored separately, even if an object drops into dictionary mode for elements, named properties may still be accessed quickly (and vice versa).

綜上,把 Array 當作 Associative Array 來用,並不會增加性能。

额。。。浅层次点说,下面2个是'等价'的:

  1. obj.attr = value
  2. obj['attr']=value

只不过2里面支持obj['attr'+var]=value,能更加灵活,比如一个循环语句里面。

控制台试试就知道咯

arr=[];
arr["color"]="red";arr["name"]="apple";

console.log(arr);
console.log(arr.length);
登录后复制

你这样做其实和使用对象是没有区别的

在javascript中,对象即关联数组,关联数组也即对象。javascript权威指南对象章节有说。
javascript也支持关联数组?与对象相比是不是存取效率更高?

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号