成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

WebAssembly 為什么比 asm.js 快?

開發 開發工具
WebAssembly 是為 Web 而設計的、可以生成瀏覽器可執行的二進制文件的編程語言。WebAssembly 的一個主要目標就是變快。本文將給出一些它如何變快的技術細節。

[[186409]]

WebAssembly 是為 Web 而設計的、可以生成瀏覽器可執行的二進制文件的編程語言。并且于2017 年 2 月 28 日,四個主要的瀏覽器一致同意宣布 WebAssembly 的 MVP 版本已經完成,即將推出一個瀏覽器可以搭載的穩定版本。WebAssembly 的一個主要目標就是變快。本文將給出一些它如何變快的技術細節。

當然,“快”是相對的概念。相比于 JavaScript 和其他動態語言,WebAssembly 的快主要是因為它的靜態類型特性和方便優化特性。WebAssembly 意在速度上能夠達到和本地執行一樣快,其實 asm.js 已經比較接近這一目標了,但是 WebAssembly 要進一步縮短和本地執行速度之間的差距。因此本文著重介紹為什么 WebAssembly 比 asm.js 更快。

在開始介紹之前,先做一些說明:新的技術總是有一些還沒來得及優化的情況,所以目前來說,并不是所有情況下 WebAssembly 都是最快的。本文主要表達的是 WebAssembly 為什么應該是更快的。對于它還不是那么快的一些情況,也是未來需要 fix 的問題。

那么有了這些標準以后,我們來介紹為什么 WebAssembly 更快。

1. 啟動

WebAssembly 設計之初就定位在:體積更小、下載更快、解析更快,這樣即使應用于一個大型的 web 應用上啟動也會很快。

JavaScript 代碼通過 gzip 進行壓縮,與本地代碼相比它已經壓縮了很多,想要進一步縮小它的體積確實不是一件容易的事情。但是通過對 WebAssembly 文件大小的精心設計(LEB128 指標),二進制格式的 WebAssembly 的文件大小要比壓縮后的 JavaScript 文件更小。通常來講,要比 gzip 壓縮后的小 10% - 20%。

WebAssembly 在解析過程有更大的進步:它的解析速度要比 JavaScript 快一個數量級。這得益于 WebAssembly 的二進制格式就是為更適合解析而設計的。同時 WebAssembly 的解析和優化函數也更容易實現并行,這一特點在多核機器上的體現更好。

影響啟動時間的因素除了下載和解析以外還有很多,比如代碼的 VM 完全優化、執行之前下載所必須的額外文件等。但是下載和解析步驟是無論如何都不可避免的步驟,因此要盡可能地對它們進行優化。不論是對于瀏覽器還是 app,其他的影響因素都有辦法避免或者緩和它們的影響(例如代碼的完全優化,可以通過 WebAssembly 的基線編譯器或解釋器來避免)。

2. CPU 特性

使得 asm.js 這么快的技巧之一是利用好 CPU 特性。JavaScript 數字類型都是 double 型的,在 asm.js 中加法操作后會有一個按位與的操作,這使得 double 加法這個操作,在邏輯上和 CPU 做簡單的 int 加法(CPU 做簡單 int 加操作很快)是等價的。而 asm.js 巧妙地通過這種方式使得 VM 可以更加有效地利用 CPU。

但是有一些 JavaScript 中表達的東西,asm.js 是表達不了的。

WebAssembly 則不受 JavaScript 的約束,我們一起來看一下更多的可利用的 CPU 特性:

64 位整型。基于 64 位整型的操作速度可以快 4 倍。例如可以增加哈希算法和加密算法的速度。

內存讀寫偏移量。它的用處特別廣泛,基本上所有包含字段的內存對象都涉及到偏移量的問題(如 C 語言中 struct 等)。

非對齊內存讀寫。這避免了 asm.js 所需要的 mask(asm.js 為 Typed Array 兼容而做的操作),同時這在幾乎所有的內存讀寫問題都用得上。

多種 CPU 指令,例如 popcount,copysign 等。每一個指令都有助于某種具體使用場景(例如,popcount 在密碼分析這個場景下很有用)。

在每一種具體場景下到底能起到多大作用,要依賴于如何使用上面提到的特性。和正常使用 asm.js 相比,我們的統計是大概比 asm.js 提升了 5% 的速率。未來還有更多可挖掘的 CPU 特性來提高速率,例如SIMD

3. 工具鏈改進

WebAssembly 是編譯器生成的主要目標,所以它的運行主要包含兩個部分:生成它的編譯器(工具鏈端)和運行它的虛擬機(瀏覽器端)。優良的性能全都依賴于這兩部分。

對于 asm.js,情況也類似,并且 Emscripten 做了一系列對工具鏈的優化,還做了運行 LLVM 的優化器和 Emscripten 的 asm.js 優化器。對 WebAssembly 的優化都是在這些的基礎上來設計的,并且同時還加入了一些專門針對 WebAssembly 的改進。我們自己在學習 asm.js 的過程對我們改善 WebAssembly 很有幫助,尤其體現在一下幾個方面:

  • 我們使用 Binaryen WebAssembly 優化器來代替 Emscripten asm.js 優化器,前者是專門為速度而設計,其速度的提升是以更多優化步驟為代價的。例如在優化的過程中會移除重復函數,這樣會使 C++ 編譯代碼整體減小 5% 左右。
  • 對冗余、復雜的控制流進行更好的優化,這可以提升 Relooper 算法的效率,對于編譯解釋類型循環也很有幫助。
  • Binaryen 優化器是在試驗中不斷設計和完善的,通過超級優化器做的實驗也會帶來各種情況的微妙改進——我想 asm.js 也做過同樣的事情。

總的來說,這些工具鏈的改進,在 asm.js 的基礎上進一步提升了 WebAssembly 的速度(Box2D 速度評測中,WebAssembly 的速度分別提升了 5% 和 7%)。

4. 可預見的優良性能

asm.js 的速度很接近本地執行的速度了,但是它不可能在所有的瀏覽器中都達到同樣的標準。因為在使用 asm.js 的過程中,一些人嘗試用一種方法來優化 asm.js,而另一些人用另一種方法優化,這導致了不同人有不同的版本和結果。雖然隨著時間的推移,大家對于 asm.js 也達成了某種共識,但是對于 asm.js 來講,本質問題是它還是沒有一個統一的標準。它只是一個由一個廠商推出的,非標準的 JavaScript 子集而已,而它的使用者根據自己的偏好和習慣來使用它。

WebAssembly 則不同,它是由幾大主要的瀏覽器廠商共同設計的。與 JavaScript相比,JavaScript 只能通過一些創新方法或者 asm.js 這種方法來提高速度,而不論哪種方法都不可能適用于所有瀏覽器。WebAssembly 的優化方案則得到了大多數廠商的認可。對于 WebAssembly 來講,對于不同的 VM 依舊有很大的提升空間(如 AOT、JIT 有不同編譯方式)。不過能夠基本斷定的是,可以應用于整個網絡的優良性能是指日可期的。

點擊《WebAssembly 為什么比 asm.js 快?》閱讀原文。

【本文是51CTO專欄作者“胡子大哈”的原創文章,轉載請聯系作者本人獲取授權】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2014-01-21 10:09:39

JavaScript編譯Asm.js

2013-12-24 09:38:50

asm.jsJavascript

2014-03-12 18:04:00

asm.jsWeb性能

2016-12-14 12:02:01

StormHadoop大數據

2017-02-14 14:20:02

StormHadoop

2013-11-27 17:14:05

FirefoxChromeOpera

2013-08-20 11:08:34

Firefox OSASM.JSDalvik

2021-01-21 07:53:29

面試官Promis打印e

2023-04-07 08:17:39

fasthttp場景設計HTTP

2025-02-04 17:24:22

2023-06-13 23:21:35

2024-02-26 21:15:20

Kafka緩存參數

2020-02-27 15:44:41

Nginx服務器反向代理

2023-06-08 18:25:40

Doris場景查詢

2020-02-27 21:03:30

調度器架構效率

2021-12-17 22:51:03

5G4G手機

2024-04-03 09:23:31

ES索引分析器

2019-02-24 22:05:12

JuliaPython語言

2020-04-14 15:18:16

SparkFlink框架

2020-03-30 15:05:46

Kafka消息數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天看逼 | 亚洲啊v | 国产乱码精品1区2区3区 | 日本成人一区二区 | 日韩1区| 欧美男男videos | 国产黄色一级片 | 亚洲视频中文字幕 | 中文字幕一区二区三区四区五区 | 欧美一区二区三区四区五区无卡码 | 91精品国产91久久久久福利 | 剑来高清在线观看 | 黄色在线观看网站 | 精品视频在线免费观看 | 一级久久久久久 | www.亚洲成人网 | 在线观看中文字幕一区二区 | 亚洲欧美日韩国产 | 免费黄色片在线观看 | 亚洲国产aⅴ成人精品无吗 欧美激情欧美激情在线五月 | 亚洲免费在线播放 | 欧美精品成人 | 欧洲亚洲一区二区三区 | 色婷婷久久久久swag精品 | 午夜精品一区二区三区在线观看 | 欧美在线国产精品 | 欧美成人精品一区二区男人看 | 男女激情网站免费 | 操操操av | 中文字幕国产视频 | av毛片在线播放 | 亚洲视频欧美视频 | 特级毛片www | 久久久黄色| 欧美一区免费 | 国产91久久久久久久免费 | 国产91亚洲精品一区二区三区 | 爱草在线| 九色网址 | 亚洲国产精品一区二区久久 | 久久伦理中文字幕 |