V8引擎隐藏类(VIP课程)

上一章我们讲了V8如何存储的对象,其中提到了隐藏类,这一章我们来看看隐藏类到底做了什么。

为什么要讲V8????

隐藏类是V8引擎在运行时自动生成和管理的数据结构,用于跟踪对象的属性和方法

隐藏类的思想借鉴了静态语言的结构

js 复制代码
function Person (name,age) {
   this.name = name;
   this.age = age;
}

let xiaoman = new Person('小满',24)

c++

cpp 复制代码
#include <iostream>
#include <string>

struct Person
{
    std::string name;
    int age;
};

int main()
{
    Person xiaoman;

    xiaoman.age = 18;
    xiaoman.name = "小满";

    std::cout << "name: " << xiaoman.name << std::endl;
    std::cout << "age: " << xiaoman.age << std::endl;

    return 0;
}

首先在JavaScript运行时,例如xiaoman.age 去查询 age 上节课我们讲过 他会 通过快慢属性 去找 而且整个过程非常耗时。

而C++就不同了,C++在声明一个对象之前需要定义该对象的结构,c++ 代码在执行之前是需要被编译的,编译的时候对象都是固定的,也就是代码执行的时候 对象的形状是无法被改变的。

所以V8就引入了 隐藏类的概念

隐藏类 (Hiden Class)

隐藏类就是把JavaScript的对象也进行静态化,我们假设这个对象不会删除和新增,这样形状就固定了

满足条件之后V8就会创建隐藏类,在这个隐藏类会创建对象的基础属性

在V8引擎中,每个隐藏类都有一个编号(map id),用于唯一标识该隐藏类

举个例子,假设我们有以下两个对象:

javaScript 复制代码
let obj1 = { name: 1, age: 2 }; 
let obj2 = { name: 1, age: 2, address: 3 };

这两个对象具有相同的形状,即都有属性nameage,但obj2还额外有一个属性address。V8会为它们生成两个不同的隐藏类

sh 复制代码
// 隐藏类1:包含属性name和age
HiddenClass_1
├── map_id: 1
├── property_names: ['name', 'age']
├── transitions: {}
└── prototype: Object.prototype

// 隐藏类2:包含属性name、age和address
HiddenClass_2
├── map_id: 2
├── property_names: ['name', 'age', 'address']
├── transitions:
│   ├── a: HiddenClass_1
│   ├── b: HiddenClass_1
│   └── c: null
└── prototype: Object.prototype

可以看到,隐藏类1包含属性nameage,没有过渡表;而隐藏类2包含属性nameageaddress,其中属性nameage的过渡表指向隐藏类1,属性address没有过渡表,表示该属性是新添加的

如果两个对象属性一样呢?

如果两个对象具有相同的属性,它们将共享同一个隐藏类。具体来说,当两个对象的属性顺序和类型都相同时,V8会为它们生成一个共享的隐藏类。

举个例子,假设我们有以下两个对象:

ini 复制代码
let obj1 = { name: 1, age: 2 };
let obj2 = { name: 1, age: 2 };

这两个对象具有相同的形状,即都有属性nameage,且属性的顺序和类型完全一致。V8会为它们生成一个共享的隐藏类,如下所示:

javascript 复制代码
HiddenClass_1
├── map_id: 1
├── property_names: ['name', 'age']
├── transitions: {}
└── prototype: Object.prototype

可以看到,隐藏类1包含属性nameage,没有过渡表,而且两个对象都共享这个隐藏类。

这种共享隐藏类的机制可以节省内存空间,因为不同的对象可以共享相同的隐藏类结构。

相关推荐
狂师2 分钟前
比 Playwright 更给力,推荐一个AI Agent的浏览器自动化开源项目!
前端·开源·测试
IT_陈寒11 分钟前
React hooks 闭包陷阱把我的状态吃掉了,原来问题出在这里
前端·人工智能·后端
壹方秘境12 分钟前
使用ApiCatcher在 iOS 上像修改 hosts 一样自定义域名解析
前端·后端·客户端
柳杉34 分钟前
可视化大屏设计器脚手架:从设计到交付的一站式方案
前端·three.js·数据可视化
kyriewen14 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒14 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮15 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦15 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer15 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队15 小时前
验证码识别实战:前端不写页面,改训模型了?
前端