V8引擎发布7.0正式版,支持WebAssembly线程预览、优化数组排序算法

简介: 该版本将会在几周内与Chrome 70稳定版一起发布,在此之前一直作为Beta版本与Chrome进行联调测试。V 7.0包涵了许多对开发人员很有帮助的新功能。本文带你一起了解其中的一些亮点。

原文作者:Michael Hablich

译者:UC 国际研发 PPP


image.png

V8团队每隔六周都会创建一个新的V8发布分支。每个版本都将在Chrome Beta到达一个milestone之前,从V8的Git的master分支拉出的。

该版本将会在几周内与Chrome 70稳定版一起发布,在此之前一直作为Beta版本与Chrome进行联调测试。V 7.0包涵了许多对开发人员很有帮助的新功能。本文带你一起了解其中的一些亮点。

Embedded built-ins

Embedded builtins 通过在多个V8隔离器之间共享生成的代码来节省内存。从V 6.9开始,我们就在x64上启用了Embedded builtins。V 7.0把这一能力扩大到了除ia32之外的所有平台,为平台节省内存。

WebAssembly线程预览

WebAssembly(Wasm)支持用C++和其他语言编写的代码在Web上运行。原生(Native)应用一个非常有用的能力是使用线程 - 用于并行计算。大多数C和C++开发人员都对pthreads比较熟悉,它是线程管理的标准API。

WebAssembly社区小组一直在努力让Web拥有真正的多线程能力。作为这项工作的一部分,V8已经为WebAssembly引擎中的线程实现了必要的支持。如果想在Chrome中使用该功能,你可以通过chrome://flags/#enable-webassembly-threads来启用,或者也可以为你的网站注册Origin Trial。Origin Trials允许开发人员在完全标准化之前尝试新的Web功能,这也有助于我们收集对新功能和改进至关重要的,真实的反馈。

Origin Trial:
https://github.com/GoogleChrome/OriginTrials

JavaScript语言的新功能

新增Symbol.prototype.description。这使得获取Symbol的描述变得更自然。在此之前,只能通过Symbol.protoype.toString()间接访问描述。感谢Igalia为这个功能的实现做出贡献!

Array.prototype.sort已经在v7.0稳定。以前,v8对于大于10个元素的数组使用“不稳定的”快速排序算法(注:排序算法不稳定,是指该算法可能改变两个相等元素的位置)。现在,我们改用TimSort算法,稳定的排序算法。有关详细信息,请参阅我们的博文。

博文地址:
https://v8.dev/blog/array-sort

V8 API

请通过 git log branch-heads/6.9..branch-heads/7.0 include/v8.h 获取API更改列表。

已经checkout过V8代码的开发者可以通过 git checkout -b 7.0 -t branch-heads/7.0 来测试的新功能。

英文原文:

https://v8.dev/blog/v8-release-70

目录
相关文章
|
1月前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习中的优化算法及其应用
【10月更文挑战第8天】 本文将探讨深度学习中常用的优化算法,包括梯度下降法、Adam和RMSProp等,介绍这些算法的基本原理与应用场景。通过实例分析,帮助读者更好地理解和应用这些优化算法,提高深度学习模型的训练效率与性能。
145 63
|
15天前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。
|
15天前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###
|
26天前
|
人工智能 算法 数据安全/隐私保护
基于遗传优化的SVD水印嵌入提取算法matlab仿真
该算法基于遗传优化的SVD水印嵌入与提取技术,通过遗传算法优化水印嵌入参数,提高水印的鲁棒性和隐蔽性。在MATLAB2022a环境下测试,展示了优化前后的性能对比及不同干扰下的水印提取效果。核心程序实现了SVD分解、遗传算法流程及其参数优化,有效提升了水印技术的应用价值。
|
25天前
|
存储 缓存 算法
优化轮询算法以提高资源分配的效率
【10月更文挑战第13天】通过以上这些优化措施,可以在一定程度上提高轮询算法的资源分配效率,使其更好地适应不同的应用场景和需求。但需要注意的是,优化策略的选择和实施需要根据具体情况进行详细的分析和评估,以确保优化效果的最大化。
|
26天前
|
并行计算 算法 IDE
【灵码助力Cuda算法分析】分析共享内存的矩阵乘法优化
本文介绍了如何利用通义灵码在Visual Studio 2022中对基于CUDA的共享内存矩阵乘法优化代码进行深入分析。文章从整体程序结构入手,逐步深入到线程调度、矩阵分块、循环展开等关键细节,最后通过带入具体值的方式进一步解析复杂循环逻辑,展示了通义灵码在辅助理解和优化CUDA编程中的强大功能。
|
26天前
|
存储 缓存 算法
前端算法:优化与实战技巧的深度探索
【10月更文挑战第21天】前端算法:优化与实战技巧的深度探索
21 1
|
27天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于贝叶斯优化CNN-LSTM网络的数据分类识别算法matlab仿真
本项目展示了基于贝叶斯优化(BO)的CNN-LSTM网络在数据分类中的应用。通过MATLAB 2022a实现,优化前后效果对比明显。核心代码附带中文注释和操作视频,涵盖BO、CNN、LSTM理论,特别是BO优化CNN-LSTM网络的batchsize和学习率,显著提升模型性能。
|
1月前
|
存储 缓存 算法
如何通过优化算法和代码结构来提升易语言程序的执行效率?
如何通过优化算法和代码结构来提升易语言程序的执行效率?
|
1月前
|
机器学习/深度学习 人工智能 算法
[大语言模型-算法优化] 微调技术-LoRA算法原理及优化应用详解
[大语言模型-算法优化] 微调技术-LoRA算法原理及优化应用详解
76 0
[大语言模型-算法优化] 微调技术-LoRA算法原理及优化应用详解
下一篇
无影云桌面