首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用v8隐藏类优化技术进行优化?

如何使用v8隐藏类优化技术进行优化?
EN

Stack Overflow用户
提问于 2015-09-09 05:08:49
回答 1查看 569关注 0票数 0

我想使用隐藏类概念,使我的网页应用程序快速。

我尝试了使用隐藏类的教程中的以下代码,但仍然显示了突然的结果。

代码语言:javascript
复制
var PROPERTIES = 10000000;

function O(size) {
  for (var i = 0; i < size; i++) {
    this[i] = null;
  }
}

var o = new O(PROPERTIES);

var start = +new Date;

for (var i = 0; i < PROPERTIES; i++) {
  o[i] = i;
}

console.log(+new Date - start);

这是用于基准测试的jsperf链接

这是正确的,还是我的实施有问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-09 07:10:11

我认为你误解了隐藏类的概念。

基本上,这两个实现都创建了隐藏类。区别在于第二个实现移动创建隐藏类来初始化状态,因此在分配实际数据时,它比第一个实现要快。

在jsfidde中,访问属性的时间是不同的。

代码语言:javascript
复制
var PROPERTIES = 10000000;

var obj = {};

var s = Date.now();

for (var i = 0; i < PROPERTIES; i++) {
   obj[i] = i;
}

console.log(Date.now() - s);

速度较慢

代码语言:javascript
复制
var PROPERTIES = 10000000;

var Class = function() {
    for (var i = 0; i < PROPERTIES; i++) {
        this[i] = null;
    }
};

var obj = new Class();

var s = Date.now();

for (var i = 0; i < PROPERTIES; i++) {
    obj[i] = i;
}

console.log(Date.now() - s);

更快

但是总执行时间是相同的,就像您在jsperf中看到的那样。

理解这一点有助于我们通过预先创建所有隐藏类来优化响应时间,因此当处理请求/逻辑时,访问属性可以更快。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32471320

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档