v8 知识梳理以及编程入门

学习 v8 编程的好处就是能够知道 node 是如何通过写JavaScript进行调用系统 API 的,如果你有c/c++又或者是比较底层的语言的基础,研究明白 v8 是如何调用系统底层的,而系统是如何提供函数给v8调用的,那么我们对 node 的理解层度就会更上一层楼。

本节主要折腾的几个事情

  • 如何通过JS调用c/c++层
  • 如何通过c/c++层调用JS层
  • 如何通过JS调用c++的类

当我们实现以上的JS-C/C++层的调用时,我们距离自己造一个node.js已经不远了

V8概念梳理

v8 执行代码的过程主要是:

  • JavaScript源码输入
  • 转换成AST(抽象语法树)
  • JIT(just in time)
  • NativeCode

这对于我们编程有了最初的印象,接下来,我们介绍一下各个内部的概念

v8::Isolate

Isolate 的概念给大家来看一定非常陌生,其英文原意是:隔离。在操作系统中,我们有一个概念和之类似:进程。进程是完全相互隔离的,一个进程里有多个线程,同时各个进程之间并不相互共享资源。Isolate 也是一样,Isolate1和Isolate2两个拥有各自堆栈的虚拟机实例,且相互完全隔离。

  • An isolate is a VM instance with its own heap. It represents an isolated instance of the V8 engine. V8 isolates have completely separate states. Objects from one isolate must not be used in other isolates.

v8::handle(v8::Local和v8:Persistent)

在新的版本中,v8::handle拆成了更为形象的两个类:v8::Local和v8:Persistent。用一个更形象的比喻,那么v8::Local更像是JavaScript中的let。在 V8 中,内存的分配都交付给了 V8,那么我们就最好不要使用自己的 new 方法来创建对象,而是使用 v8::Local 里的各种方法来创建一个对象。由v8::Local创建的对象,能够被 v8 自动进行管理,也就是传说中的GC(垃圾清理机制)。

Persistent代表的是持久的意思,更类似全局变量,申请和释放一定要记得使用:Persistent::New, Persistent::Dispose这两个方法,否则会内存侧漏。

Scope

Scope是一个比较小范围的GC单元,分别有v8::HandleScopev8::Context::Scope

v8::HandleScope一般情况下,HandleScope会在一个函数的开头进行声明,然后用于管理这整个函数所创建的Handle,而v8::Context::Scope也类似,只不过他是直接管理context对象的。

void F(){
    //一开头放一个
    v8::HandleScope handle_scope(isolate);
    v8::Local<v8::String> source1 =.......
    v8::Local<v8::String> source2 =......

    //开头放一个
    v8::Local<v8::Context> context = Context::New(isolate);
    v8::Context::Scope context_scope(context);
}

这样一来,整个函数的handle和context就会被这两个scope分别管理起来,函数跑完了,那么就会自动释放掉了。

Context

Context的概念我更喜欢把比喻成闭包,虽然不是,但是很像。在V8里面,Context主要是用于创建一个JavaScript的运行上下文环境。更形象生动的说法是Html的iFrame,一个网页中可以有多个iFrame,每个iFrame又有不同的运行环境。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 226,780评论 6 526
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 97,642评论 3 411
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 174,427评论 0 373
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 62,220评论 1 306
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 71,026评论 6 405
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 54,544评论 1 319
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 42,643评论 3 433
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 41,796评论 0 283
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 48,300评论 1 329
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 40,281评论 3 352
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 42,426评论 1 364
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,988评论 5 354
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 43,684评论 3 342
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 34,090评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 35,311评论 1 280
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 51,002评论 3 385
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 47,409评论 2 370

推荐阅读更多精彩内容