[譯]JavaScript 究竟是如何工作的?(第一部分)

  • 原文地址:How Does JavaScript Really Work? (Part 1)
  • 原文作者:Priyesh Patel

如果你是一個 JS 開發者或者是正在學習這門語言的學生,很大概率上你會遇到雙字母詞"V8"。在這篇文章中,我將會為你簡述不同的 JS 引擎并深入探究 V8 引擎的工作機制。文章的第二部分涵蓋了內存管理的概念,不久后將發布。

這篇文章是由 Bit (GitHub) 帶來的。作為一個共享組件的平臺,Bit 幫助每個人構建模塊化的 JavaScript 應用程序,在項目和團隊之間輕松地共享組件,同時實現更好&更快的構建。試試看。

1.編程語言是如何工作的?

在開始講解 JavaScript 之前,我們首先要理解任意一門編程語言的基本工作方式。電腦是由微處理器構成的,我們通過書寫代碼來命令這臺小巧但功能強大的機器。但是微處理器能理解什么語言?它們無法理解 Java,Python 等語言,而只懂機器碼。 用機器語言或匯編語言編寫企業級代碼是不可行的,因此我們需要像 Java,Python 這樣配帶一個解釋器或者編譯器用于將其轉換為機器碼的高級語言。

1.1編譯器和解釋器

編譯器/解釋器可以用它處理的語言或任何其他語言來編寫。

解釋器: 一行一行地快速讀取和翻譯文件。這就是 JavaScript 最初的工作原理。

編譯器: 編譯器提前運行并創建一個文件,其中包含了輸入文件的機器碼轉換。

有兩種途徑可以將 JavaScript 代碼轉換為機器碼。編譯代碼時,機器對代碼開始運行前將要發生的事情有更好的理解,這將加快稍后的執行速度。不過,在這個過程之前需要花費時間。

另一方面,解釋代碼時,執行是立即的,因此要更快,但是缺乏優化導致它在大型應用程序下運行緩慢。

創建 ECMAScript 引擎的人很聰明,他們集二者之長開發了 JIT(Just-in-time) 編譯器。JavaScript 同時被編譯和解釋,但實際實現和順序取決于引擎。我們將會看到 V8 團隊采用的是什么策略。

2.從 JavaScript 到機器碼

就 JavaScript 而言,有一個引擎將其轉換為機器碼。和其他語言類似,引擎可以用任何語言來開發,因此這樣的引擎不止一個。

  • V8 是谷歌針對 Chorme 瀏覽器的引擎實現。
  • SpiderMonkey 是第一個引擎,針對網景瀏覽器開發,現用于驅動 FireFox。
  • JavaScriptCore 是蘋果針對 Safari 瀏覽器使用的引擎。

還有很多,如果你想知道 Internet Explorer 背后的引擎,查看這個維基百科頁面.

2.1 ECMAScript

面對這么多的引擎,你可能會問:我可以開發自己的引擎嗎?可以,只要遵循 ECMAScript 標準。

如果我們打算做一個翻譯器,那么就必須知道這兩門語言的有效字。我們已經知道機器語言中什么是有效的了,但是對于 JavaScript,這是需要進行標準化的。

JavaScript 的標準化工作是由 Ecma 國際組織負責的,相關規范被稱為 ECMAScript 或者 ES。因此,當你看到一篇文章/視頻提到“ES7 有什么新特性?”時,你就知道它代表的是 ECMAScript 標準中新增的 JS 特性。

3.V8?引擎

3.1 部分歷史

谷歌針對瀏覽器開發了谷歌地圖,而這對瀏覽器的處理能力提出了很高的要求。那時的 JavaScript 實現尚不足以快速地運行地圖。谷歌想要吸引更多的用戶使用這項服務,從而進行廣告銷售并牟利。基于這個原因,這項服務必須快速且穩定。因此谷歌自己用 C++ 開發了 V8 引擎并在 2008 年啟用,它的速度很快,或者就像一些人說的,它的速度是最快的。

3.2 解析和構建樹

JavaScript 文件進入引擎后,解析器進行詞法解析,它將代碼分解成 token 以確定它們的含義。這些 token 組成了AST(抽象語法樹)。

編譯器在語義分析中驗證語言元素和關鍵詞的正確用法,而 ASTs 在這個過程中扮演著重要的角色。之后,ASTs 被用于生成實際的字節碼或者機器碼。

3.3 引擎的核心

  • 我們之前談到,JavaScript 是由 Ignition 這個解釋器解釋的,同時由 TurboFan 這個 JIT 優化編譯器進行編譯。
  • 首先,前面步驟生成的 ASTs 傳遞給解釋器,該解釋器迅速生成未經過優化的機器碼,并且其執行是無延遲的。
  • Profiler 在代碼運行時進行觀察,找出可以進行優化的地方。例如,一個‘for’循環跑了 100 次,但是每次迭代產生的結果都是一樣的。
  • 使用這個分析器后,任何未優化的代碼都將傳遞給編譯器以進行優化,同時生成機器碼,它最終會替換掉之前由解釋器生成的未優化代碼中的對應部分。
  • 隨著分析器和編譯器不斷地更改字節碼,JavaScript 的執行性能逐漸提高。

3.4 更多歷史

在V8 的 5.9 版本推出之前,它使用兩個優化編譯器和一個基線編譯器。

  • 基線編譯器 full-codegen 迅速生成未優化的機器碼。
  • 兩個優化編譯器 Crankshaft 和 TurboFan 用于優化代碼。

JavaScript 增加了新的特性后,架構的復雜度上升,維護相同的管道對 V8 團隊來說變得更加困難了。如果你想相關的舊方法以及轉向新管道的原因,可以訪問他們的網站。

3.5 放眼未來

隨著更多進一步提升性能的研究的進行,V8 引擎的工作機制在未來還可能發生變化。此外,隨著 Webassembly 逐漸成形,可能會向管道添加額外步驟。

4.結論

ECMAScript 引擎的實現有很多,其中以谷歌的 V8 最為出名。希望這篇文章的簡述不僅可以幫助你理解 JavaScript 的工作原理,還能從大體上了解一門編程語言的工作原理。如果你想了解 V8 團隊的未來計劃或者引擎的細節,這里有一篇很不錯的博客。

本文的第二部分將會在不久后發布,其中將談到內存堆,棧,事件循環以及更多與 JavaScript 代碼執行相關的概念。敬請關注!

如果你不清楚 Node.js 在其中的作用,我這里碰巧寫了一篇不錯的文章: What exactly is Node.js?

轉載于:https://juejin.im/post/5cef7f1be51d45777811732c

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/448708.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448708.shtml
英文地址,請注明出處:http://en.pswp.cn/news/448708.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vue實戰(9):總結二

整理前一段所做的工作內容 0.其它 vue實戰(1):準備與資料整理vue實戰(2):初始化項目、搭建底部導航路由vue實戰(3):底部導航顯示、搭建各模塊靜態頁面、添加登錄頁頁面與…

一名IT從業者的英語口語能力成長路徑

這篇文章是我最近十天口語系列文章的合輯,文章比較長,一萬五千余字。但是系統化地歸納了自己十多年的英語尤其是口語方面的學習經歷與總結思考。我不是個純粹的英語專業學生,我甚至不是任何英語相關專業的學生,但是我和英語卻有著…

解決:SpringBoot 錯誤:Caused by: org.yaml.snakeyaml.scanner.ScannerException

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 錯誤: Caused by: org.yaml.snakeyaml.scanner.ScannerException: while scanning for the next tokenfound character that cannot s…

好程序員前端分享使用JS開發簡單的音樂播放器

好程序員前端分享使用JS開發簡單的音樂播放器,最近,我們在教學生使用JavaScript,今天就帶大家開發一款簡單的音樂播放器。首先,最終效果如圖所示:首先,我們來編寫html界面index.html,代碼如下:&…

學生管理系統stuSystem函數

void stuSystem(){ struct student *head,*stu; int lookup_num; int Delete_num; int Modify_num; char ckeya; int istate0; do { system("cls"); //vc清屏函數&#xff0c;包含在#include<stdlib.h>中 printf(" 歡迎進入學生管理系統&#xff01;\n&q…

OpenCL用于計算機領域的13個經典案例

摘要&#xff1a;當使用加速器和OpenCL時&#xff0c;哪種類型的算法更加快速&#xff1f;來自弗吉尼亞理工大學的Wu Feng教授和他的團隊例舉了一份算法列表&#xff0c;分享了OpenCL常被用于計算機領域的13個經典案例。 哪種算法可以最好的映射GPU及矢量處理器呢&#xff1f;…

版本控制:集中式(SVN) vs 分布式(GIT)

Linus一直痛恨的CVS及SVN都是集中式的版本控制系統&#xff0c;而Git是分布式版本控制系統&#xff0c;集中式和分布式版本控制系統有什么區別呢&#xff1f; 先說集中式版本控制系統&#xff0c;版本庫是集中存放在中央服務器的&#xff0c;而干活的時候&#xff0c;用的都是…

Knative 核心概念介紹:Build、Serving 和 Eventing 三大核心組件

為什么80%的碼農都做不了架構師&#xff1f;>>> 作者| 阿里云智能事業群高級開發工程師 元毅 Knative 主要由 Build、Serving 和 Eventing 三大核心組件構成。Knative 正是依靠這三個核心組件&#xff0c;驅動著 Knative 這艘 Serverless 巨輪前行。下面讓我們來分…

樹莓派基金會來號召用鍵盤生物學家研究企鵝

倫敦動物學會&#xff08;Zoological Society of London&#xff09;于2014年&#xff0c;與伍茲霍爾海洋研究所和牛津大學等組織合作監控企鵝的計劃Penguin Lifelines有了新進展&#xff0c;倫敦動物學會現與其他動物保護組織合作Penguin Watch項目&#xff0c;邀請民眾在網上…

BlockingCollectionT 類實現 列隊操作

官方文檔 為實現 IProducerConsumerCollection<T> 的線程安全集合提供阻塞和限制功能。 通過 BlockingCollection<T> 實現列隊調用函數 建立全局變量 BlockingCollection<string> blockingCollection new BlockingCollection<string>(); 建立調用函數…

Git 版本回退

現在&#xff0c;你已經學會了修改文件&#xff0c;然后把修改提交到Git版本庫&#xff0c;現在&#xff0c;再練習一次&#xff0c;修改readme.txt文件如下&#xff1a; Git is a distributed version control system. Git is free software distributed under the GPL.然后嘗…

AMD院士站臺 異構計算與OpenCL編程師資培訓首站清華開講

摘要&#xff1a;2013年10月14日&#xff0c;“2013年異構計算與OpenCL編程師資培訓”在清華大學召開。本活動邀請到AMD、Khronos Group及清華大學的多位并行計算領域專家&#xff0c;與參會者共同探討OpenCL異構開發和優化技術。 2013年10月14日&#xff0c;由教育部科技發展…

【問題記錄】RIDE-1.7.3.1控制臺及日志中文亂碼處理

RIDE-1.7.3.1運行結果界面展示: 解決方法參考鏈接&#xff1a; https://blog.csdn.net/panda62/article/details/88535376 轉載于:https://www.cnblogs.com/quietCorner/p/11046656.html

GPU Saturday技術沙龍:OpenCL程序員眼中的下一代APU架構

摘要&#xff1a;GPU Saturday技術沙龍在北京3WCoffee成功舉辦。本次活動邀請AMD資深技術人員及清華大學項目研究員就AMD最新的GCN架構、GPU加速計算在挖掘比特幣、典型圖像算法、深度神經網絡算法等領域的分析與應用展開深入討論。 [CSDN報道] 9月5日&#xff0c;GPU Saturda…

直接取出 post 請求中的 json、得請求體參數、查看 post 請求參數

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 方法如下&#xff1a; try{ServletRequestAttributes requestAttributes (ServletRequestAttributes) RequestContextHolder.getReques…

SparkSQL調優

1、執行計劃&#xff08;過往記憶https://www.iteblog.com/archives/2562.html&#xff09; df.explain(true)//顯示邏輯計劃和物理計劃&#xff0c;不加true只顯示物理計劃 2、邏輯計劃優化方法&#xff1a; 謂詞下推&#xff0c;列裁剪&#xff0c;常量替換&#xff0c;常量累…

AMD發布APPML源碼,構建clMath庫

摘要&#xff1a;日前&#xff0c;AMD將加速并行處理數學庫&#xff08;Accelerated Parallel Processing Math Library簡稱APPML&#xff09;開源&#xff0c;內容包含了BLAS和FFT的OpenCL實現&#xff0c;項目托管在GitHub上&#xff0c;命名為clMath&#xff0c;該項目基于A…

最簡單的 post 請求發起方式、調用其它系統接口

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 調用其它系統接口&#xff0c;發起一個 post 請求&#xff0c;寫法如下&#xff1a; import cn.com.infinitus.yunxiao.jira.vo.EpicV…

CSS基礎學習 18.CSS多列

四種常見的瀏覽器內核&#xff1a; 轉載于:https://www.cnblogs.com/songsongblue/p/11050210.html

BGP

BGP&#xff1a;border gateway protocol 邊界網關路由協議 路由協議分類&#xff1a;內部網關路由協議IGP&#xff1a;rip ospf isis &#xff08;eigrp&#xff09;外部 網關路由協議EGP&#xff1a;EGP&#xff08;早期淘汰&#xff09; BGP BGP特點&#xff1a;1、針對大型…