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

JavaScript是如何工作的:引擎,運行時和調用堆棧的概述!

開發 前端
本文是旨在深入研究JavaScript及其實際工作原理的系列文章中的第一篇:我們認為通過了解JavaScript的構建塊以及它們是如何工作的,將能夠編寫更好的代碼和應用程序。

 本文是旨在深入研究JavaScript及其實際工作原理的系列文章中的***篇:我們認為通過了解JavaScript的構建塊以及它們是如何工作的,將能夠編寫更好的代碼和應用程序。我們還將分享構建 SeStHealsStad 時使用的一些經驗法則,這是一個輕量級的 JavaScript 應用程序,必須保持健壯和高性能以保持競爭力。

如 GitHut 統計 數據所示,在GitHub中的活動存儲庫和總推送方面,JavaScript處于頂部。它也不落后于其他類別。

如果項目越來越依賴于 JavaScript,這意味著開發人員必須利用語言和生態系統提供的所有內容,對內部進行更深入的了解,以便構建出色的軟件。

事實證明,有很多開發人員每天都在使用JavaScript,但卻不知道背后發生了什么。

概述

幾乎每個人都已經聽說過 V8 引擎,大多數人都知道 JavaScript 是單線程的,或者它使用的是回調隊列。

在本文中,我們將詳細介紹這些概念,并解釋 JavaScrip 實際如何運行。通過了解這些細節,你將能夠適當地利用所提供的 API 來編寫更好的、非阻塞的應用程序。

如果您對JavaScript還比較陌生,那么本文將幫助您理解為什么JavaScript與其他語言相比如此“怪異”。

如果你是一個有經驗的JavaScript開發人員,希望它能讓您對每天使用的JavaScript運行時的實際工作方式有一些新的見解。

JavaScript引擎

JavaScript引擎的一個流行示例是Google的V8引擎。例如,在Chrome和Node.js中使用V8引擎,下面是一個非常簡化的視圖:

[[252370]]

V8引擎由兩個主要部件組成:

  •  emory Heap(內存堆) — 內存分配地址的地方
  •  Call Stack(調用堆棧) — 代碼執行的地方

Runtime(運行時)

有些瀏覽器的 API 經常被使用到(比如說:setTimeout),但是,這些 API 卻不是引擎提供的。那么,他們是從哪兒來的呢?事實上這里面實際情況有點復雜。

所以說我們還有很多引擎之外的 API,我們把這些稱為瀏覽器提供 API 稱為 Web API,比如說 DOM、AJAX、setTimeout等等。

然后我們還擁有如此流行的事件循環和回調隊列。

調用棧

JavaScript是一種單線程編程語言,這意味著它只有一個調用堆棧。因此,它一次只能做一件事。

調用棧是一種數據結構,它記錄了我們在程序中的位置。如果我們運行到一個函數,它就會將其放置到棧頂,當從這個函數返回的時候,就會將這個函數從棧頂彈出,這就是調用棧做的事情。

來個栗子:

當程序開始執行的時候,調用棧是空的,然后,步驟如下:

每一個進入調用棧的都稱為調用幀。

這能清楚的知道當異常發生的時候堆棧追蹤是怎么被構造的,堆棧的狀態是如何的,讓我們看一下下面的代碼:

如果這發生在 Chrome 里(假設這段代碼實在一個名為 foo.js 的文件中),那么將會生成以下的堆棧追蹤:

"堆棧溢出",當你達到調用棧***的大小的時候就會發生這種情況,而且這相當容易發生,特別是在你寫遞歸的時候卻沒有全方位的測試它。我們來看看下面的代碼:

當引擎開始執行這段代碼時,它首先調用函數“foo”。然而,這個函數是遞歸的,并且在沒有任何終止條件的情況下開始調用自己。因此,在執行的每一步中,相同的函數都會被一次又一次地添加到調用堆棧中,如下所示:

然而,在某些時候,調用堆棧中的函數調用數量超過了調用堆棧的實際大小,瀏覽器決定采取行動,拋出一個錯誤,它可能是這樣的:

在單個線程上運行代碼很容易,因為你不必處理在多線程環境中出現的復雜場景——例如死鎖。

但是在一個線程上運行也非常有限制,由于 JavaScript 只有一個調用堆棧,當某段代碼運行變慢時會發生什么?

并發與事件循環

當調用堆棧中的函數調用需要花費大量時間來處理時會發生什么情況? 例如,假設你希望在瀏覽器中使用JavaScript進行一些復雜的圖像轉換。

你可能會問-為什么這是一個問題?問題是,當調用堆棧有函數要執行時,瀏覽器實際上不能做任何其他事情——它被阻塞了,這意味著瀏覽器不能呈現,它不能運行任何其他代碼,它只是卡住了,如果你想在應用中使用流暢的頁面效果,這就會產生問題。

而且這不是唯一的問題,一旦你的瀏覽器開始處理調用棧中的眾多任務,它可能會停止響應相當長一段時間。大多數瀏覽器都會這么做,報一個錯誤,詢問你是否想終止 web 頁面。

這并不是***的用戶體驗,不是嗎?

那么,我們怎樣才能在不阻塞UI和不使瀏覽器失去響應的情況下執行大量代碼呢?解決方案是異步回調。

這個在下一篇說明,我盡快把原作者的內容整理好!

與此同時,如果你理解JavaScript應用程序中的問題方面遇到困難,請查看SessionStack。SessionStack 記錄 web 應用程序中的所有內容:所有 DOM 更改、用戶交互、JavaScrip t異常、堆棧跟蹤、失敗的網絡請求和調試消息。

使用SessionStack,您可以在web應用程序中以視頻的形式重播問題,并查看發生在用戶身上的所有事情。 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2021-09-11 15:38:23

容器運行鏡像開放

2019-01-14 08:06:37

JavaScript

2023-07-28 10:42:43

2021-03-15 08:33:01

CC++動態庫

2022-10-08 00:00:00

V8channel對象

2015-07-20 15:44:46

Swift框架MJExtension反射

2020-12-07 13:31:43

GoMutex開發者

2021-08-18 08:32:09

代碼運行時間示波器

2020-08-11 08:59:20

容器虛擬化技術

2015-09-09 10:10:35

運行時改變圖標

2024-03-21 09:15:58

JS運行的JavaScrip

2018-04-08 14:27:45

Linuxuptime系統運行時間

2017-01-19 20:28:44

2023-08-27 21:07:02

2023-08-21 09:37:57

MySQL工具MariaDB

2024-01-29 08:07:42

FlinkYARN架構

2020-04-06 11:47:44

Linux命令腳本

2022-11-04 09:09:54

Linux服務器

2017-12-17 16:34:18

JavaScript代碼V8

2019-04-17 13:48:19

JavaScript前端傳遞
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费精品一区 | 欧美日韩在线观看一区二区三区 | 一级黄色裸片 | 欧美精产国品一二三区 | 国精产品一区二区三区 | 91成人免费电影 | 热re99久久精品国99热观看 | 成人免费视频网站在线观看 | 精品国产91亚洲一区二区三区www | 国产一区免费 | 欧美日韩高清一区二区三区 | 亚洲一区二区三区四区五区中文 | 国产日韩一区二区三免费 | 中文字幕在线网 | 成人在线观看免费爱爱 | 暖暖日本在线视频 | 久久精品网 | www.色.com| 国产区久久 | 成人免费在线观看视频 | 亚洲国产午夜 | 亚洲精品久久久久久首妖 | 久久精品一区二区三区四区 | 国产黄色大片在线免费观看 | 欧美成人精品一区二区男人看 | 精品国产欧美一区二区三区成人 | 99热精品在线 | 日韩精品一区二区三区在线观看 | 欧美精品一区二区在线观看 | 国产成人精品视频在线观看 | 亚洲美女视频 | 久久中文字幕av | 三区四区在线观看 | 91高清视频在线观看 | 国产精品久久久久久久久久久久久 | 国产欧美久久一区二区三区 | 中文字幕 欧美 日韩 | 风间由美一区二区三区在线观看 | 欧美不卡在线 | 亚洲www啪成人一区二区 | 狠狠干在线 |