博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS 引擎 V8 新机制:JIT-less 模式
阅读量:4117 次
发布时间:2019-05-25

本文共 1461 字,大约阅读时间需要 4 分钟。

640?wx_fmt=jpeg

来源 | 开源中国

原文 | https://v8.dev/blog/jitless

V8 v7.4 现在支持无需在 runtime 阶段分配可执行内存就能执行 JavaScript 代码。

在其默认配置中,V8 很大程度上依赖于在 runtime 阶段分配和修改可执行内存的能力。例如,作为一个包含优化过程的编译器,TurboFan 可即时(just-in-time)为热加载 JavaScript(JS) 函数创建原生代码,并且大多数 JS 正则表达式由 irregexp 引擎编译为原生代码。而在 runtime 阶段支持创建可执行内存正是 V8 快速运行的原因之一。

但在某些场景中,我们可能需要刚好需要在不分配可执行内存的情况下运行 V8:

  1. 某些平台(例如 iOS、智能电视、游戏控制台)禁止对非特权应用程序的可执行内存进行写访问,因此到目前为止,在这些平台上一直无法使用 V8

  2. 禁止对可执行内存进行写操作可减少应用程序的攻击面

为此,V8 引入了名为 "JIT-less" 的新模式,旨在解决上面这些问题。当 V8 启动时带上 --jitless 参数,它就可以在没有使用任何 runtime 的情况下(无需分配可执行内存)来运行。

到这里,可能有人会问,这个 "JIT-less" 的工作原理到底是什么?对此,官方给出了解释。本质上,V8 只是基于现有的技术切换到了仅使用解释器(interpreter-only)模式:所有 JS 代码都通过 Ignition 解释器运行,同时对正则表达式模式匹配进行解释。虽然目前暂不支持 WebAssembly,不过可以对其进行解释。

而对于 V8 的内置程序,仍会将其编译为原生代码。但开发团队表示最近正努力将这些内置程序嵌入到 V8 二进制文件中,所以它们以后不再是 JS 堆栈。

最后,这些变更使得开发者所创建的 V8 不需要在任何内存区域申请可执行权限。

测试结果

正如上文所提到的,由于在 JIT-less 模式下禁用了优化编译器,因此会降低性能。

为此,开发团队研究了各种基准测试,以更好了解 V8 的性能是如何变化的。本次测试的比较对象包括:Speedometer 2.0、Web Tooling Benchmark 以及 YouTube TV Browsing

Speedometer 2.0 旨在代表典型的 Web 应用程序;Web Tooling Benchmark 包含了一系列常见的 JS 开发者工具;此外还提供了一个模拟在 Youtube 直播间浏览的基准测试。所有测试均在 x64 Linux 桌面系统上本地进行,运行次数超过5次。

640?wx_fmt=png

△分数越高越好

可以看到,在 JIT-less 模式下,Speedometer 2.0 的性能大概下降了 40%。其中禁用的优化编译器占了大约一半的原因,另一半原因则是由正则表达式解释器引起的,该解释器最初用作调试辅助工具。

由于 Web Tooling Benchmark 会在 TurboFan 中花费更多时间,即它会重度依赖 TurboFan,因此在启用 JIT-less 模式后,测试结果显示下降了大约 80%。

对于最后的测试对象,可以看到性能变化不大。其测试过程包括视频播放和菜单导航,所以即使在 JIT-less 模式下,嵌入器也可以保持合理的性能。

最后,开发团队鼓励在受限制的平台或具有特殊安全要求的场景中尝试使用 V8 的新 JIT-less 模式,现在可在 V8 v7.4 版本中使用。

640?wx_fmt=jpeg

640?wx_fmt=jpeg

转载地址:http://jddpi.baihongyu.com/

你可能感兴趣的文章
Tester测试模板
查看>>
如何从windows远程控制Ubuntu
查看>>
编译Zimbra
查看>>
安装Zimbra
查看>>
raw file(audio file format) How to convert endianness
查看>>
win64位下Python2.7安装pyXML问题解决方案
查看>>
[git]暂存区的存在的意义在哪?
查看>>
[JAVA]web开发,你必须要了解的web后端发展史
查看>>
一张图看懂什么是MVC,三层结构,AOP,IOC。以及他们的区别与联系
查看>>
解决xyplorer删除后,显示“找不到应用程序”错误
查看>>
typora添加页内跳转/页内超链接
查看>>
bios和uefi区别
查看>>
什么是javaweb开发?
查看>>
解决tomcat无法用浏览器访问localhost:8080的思路
查看>>
为什么是List list = new ArrayList(),而不直接用ArrayList
查看>>
一句话明白主键约束和唯一约束的区别
查看>>
三种范式的最通俗理解,包会的那种
查看>>
笛卡尔积的作用
查看>>
大数据系列之ELK集群环境部署
查看>>
大数据系列之Kafka集群环境部署
查看>>