Javascript 如何使用v8隐藏类优化技术进行优化?
我想使用隐藏类的概念使我的web应用程序快速 我从一个关于使用隐藏类的教程中尝试了以下代码,但仍然显示了突然的结果Javascript 如何使用v8隐藏类优化技术进行优化?,javascript,node.js,v8,libv8,Javascript,Node.js,V8,Libv8,我想使用隐藏类的概念使我的web应用程序快速 我从一个关于使用隐藏类的教程中尝试了以下代码,但仍然显示了突然的结果 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 < PROPE
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);
var属性=10000000;
功能O(尺寸){
对于(变量i=0;i
这是
我的实现是正确的还是有问题?我认为您误解了隐藏类的概念 基本上,这两种实现都创建了隐藏类。区别在于第二个实现将创建隐藏类移动到初始化状态,因此在分配实际数据时,它比第一个实现快 在JSFIDE中,访问属性的时间是不同的
var PROPERTIES = 10000000;
var obj = {};
var s = Date.now();
for (var i = 0; i < PROPERTIES; i++) {
obj[i] = i;
}
console.log(Date.now() - s);
var属性=10000000;
var obj={};
var s=Date.now();
对于(变量i=0;i
var属性=10000000;
var类=函数(){
对于(变量i=0;i
但是总的执行时间是相同的,正如您在jsperf中看到的那样
了解这一点有助于我们通过预先创建所有隐藏类来优化响应时间,因此在处理请求/逻辑时,访问属性的速度会更快。您认为为什么会在此处创建隐藏类?您正在构造函数中设置所有属性,并且只更改相同(现有)属性的值属性。@msdex:我想他是在遵循这个链接:性能怎么可能有如此大的变化呢?但这与隐藏类无关-首先,V8不会为每个单独的索引属性分配创建隐藏类(索引属性是
0
,1
,等等)。索引属性的处理方式与隐藏类系统中的命名属性完全不同。您看到的性能差异都是由于阵列预分配造成的。您关注的@Amir的原始帖子在解释发生的事情时存在缺陷。不管上面写的是什么。
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);