国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

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

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

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

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

如果項目越來越依賴于 JavaScript,這意味著開發(fā)人員必須利用語言和生態(tài)系統(tǒng)提供的所有內(nèi)容,對內(nèi)部進行更深入的了解,以便構(gòu)建出色的軟件。

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

概述

幾乎每個人都已經(jīng)聽說過 V8 引擎,大多數(shù)人都知道 JavaScript 是單線程的,或者它使用的是回調(diào)隊列。

在本文中,我們將詳細介紹這些概念,并解釋 JavaScrip 實際如何運行。通過了解這些細節(jié),你將能夠適當(dāng)?shù)乩盟峁┑?API 來編寫更好的、非阻塞的應(yīng)用程序。

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

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

JavaScript引擎

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

[[252370]]

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

  •  emory Heap(內(nèi)存堆) — 內(nèi)存分配地址的地方
  •  Call Stack(調(diào)用堆棧) — 代碼執(zhí)行的地方

Runtime(運行時)

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

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

然后我們還擁有如此流行的事件循環(huán)和回調(diào)隊列。

調(diào)用棧

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

調(diào)用棧是一種數(shù)據(jù)結(jié)構(gòu),它記錄了我們在程序中的位置。如果我們運行到一個函數(shù),它就會將其放置到棧頂,當(dāng)從這個函數(shù)返回的時候,就會將這個函數(shù)從棧頂彈出,這就是調(diào)用棧做的事情。

來個栗子:

當(dāng)程序開始執(zhí)行的時候,調(diào)用棧是空的,然后,步驟如下:

每一個進入調(diào)用棧的都稱為調(diào)用幀。

這能清楚的知道當(dāng)異常發(fā)生的時候堆棧追蹤是怎么被構(gòu)造的,堆棧的狀態(tài)是如何的,讓我們看一下下面的代碼:

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

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

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

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

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

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

并發(fā)與事件循環(huán)

當(dāng)調(diào)用堆棧中的函數(shù)調(diào)用需要花費大量時間來處理時會發(fā)生什么情況? 例如,假設(shè)你希望在瀏覽器中使用JavaScript進行一些復(fù)雜的圖像轉(zhuǎn)換。

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

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

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

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

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

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

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

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2021-09-11 15:38:23

容器運行鏡像開放

2019-01-14 08:06:37

JavaScript

2023-07-28 10:42:43

2022-10-08 00:00:00

V8channel對象

2021-03-15 08:33:01

CC++動態(tài)庫

2015-07-20 15:44:46

Swift框架MJExtension反射

2021-08-18 08:32:09

代碼運行時間示波器

2020-12-07 13:31:43

GoMutex開發(fā)者

2020-08-11 08:59:20

容器虛擬化技術(shù)

2015-09-09 10:10:35

運行時改變圖標(biāo)

2024-03-21 09:15:58

JS運行的JavaScrip

2018-04-08 14:27:45

Linuxuptime系統(tǒng)運行時間

2017-01-19 20:28:44

2020-04-06 11:47:44

Linux命令腳本

2023-08-27 21:07:02

2024-01-29 08:07:42

FlinkYARN架構(gòu)

2023-08-21 09:37:57

MySQL工具MariaDB

2022-11-04 09:09:54

Linux服務(wù)器

2017-12-17 16:34:18

JavaScript代碼V8

2019-04-17 13:48:19

JavaScript前端傳遞
點贊
收藏

51CTO技術(shù)棧公眾號

日韩大片免费观看视频播放| http;//www.99re视频| 青青国产在线| 91一区一区三区| 亚洲7777| 亚洲免费网站| 成人羞羞视频免费| 91亚洲国产成人久久精品| 97在线视频观看| 欧美日韩黄网站| 最近的2019中文字幕免费一页| 丁香花在线电影小说观看| 欧洲一区二区三区在线| 日本三级电影网| 亚洲老妇xxxxxx| 777视频在线观看| 亚洲色图在线播放| 免费观看一二区视频网站| 国产精品久久久久久户外露出| 国产99久久九九精品无码| 国产揄拍国内精品对白| 亚洲小说欧美另类激情| 国产一二三精品| 国产日韩亚洲欧美在线| 蜜桃91丨九色丨蝌蚪91桃色| 伊人久久大香线蕉午夜av| 黄一区二区三区| 国产aaa免费视频| av亚洲精华国产精华| 午夜肉伦伦影院| 国产日韩欧美a| 日本五十路在线| 色婷婷精品大视频在线蜜桃视频| 成人av毛片| 亚洲国产黄色片| 九九热这里有精品| 欧美交受高潮1| 精品中文一区| 国产综合第一页| 日韩成人免费电影| 国产婷婷一区二区三区| 中文子幕无线码一区tr | 久久中文字幕av| 国产视频一区二区三区四区| 日韩中文字幕区一区有砖一区| 欧美a级黄色大片| 99v久久综合狠狠综合久久| 91欧美视频在线| 欧美日韩中文字幕在线| 欧美男男video| 日韩在线观看精品| 国产一区二区三区四区二区| 精品一区二区视频| www.亚洲在线| 高清色视频在线观看| 欧美一区二区三区在线| 91成人精品观看| 91传媒视频在线观看| 国产综合色在线视频区| jlzzjlzz欧美大全| 91精品国产综合久久福利| 国产精品一区二区三区四区在线观看| 国产精品大陆在线观看| 日日摸夜夜添夜夜添精品视频 | 异国色恋浪漫潭| 91在线视频官网| 男人av在线| 在线日韩欧美视频| 日韩精品欧美| 久久这里只有精品18| 婷婷开心激情综合| 日韩色淫视频| 国产精品国产三级国产专区53| 99在线热播精品免费| 国产免费av高清在线| 久久精品中文字幕电影| 雨宫琴音一区二区在线| 午夜激情福利在线| 日韩欧美中文一区| 精品免费av| 91免费黄视频| 欧美日韩电影在线播放| 欧美日韩导航| 国产日韩第一页| 色域天天综合网| 国产精品调教视频| 奇米777四色影视在线看| 色综合久久久久久久久| 日韩免费成人| 一区不卡字幕| 色综合夜色一区| 在线视频亚洲欧美中文| 午夜精品一区二区三区在线观看| 亚洲综合图片区| 精品一区二区三区亚洲| 影音先锋欧美资源| 在线免费观看成人短视频| 欧美交a欧美精品喷水| wwwwww欧美| 日韩区在线观看| 伊人久久大香线| 免费观看的av网站| 九九精品视频在线| 国产成人av在线影院| 亚洲综合图区| 99电影网电视剧在线观看| 国产精品大尺度| 欧美国产亚洲精品| 国产欧美日韩网站| 亚洲区免费影片| 久久国内精品视频| 国产高清在线a视频大全| 精品中文字幕人| 欧美综合一区二区| 一区二区三区四区电影| 在线视频您懂的| 国产精品第8页| 中文字幕五月欧美| 大奶一区二区三区| 无码人妻丰满熟妇区96| 一区二区三区www| 国产精品夜夜嗨| 天堂电影一区| 亚洲一区3d动漫同人无遮挡 | 日av中文字幕| 最近免费中文字幕视频2019| 精彩视频一区二区| 污污视频在线看| 久久综合一区| 欧美一区二区三区人| 日韩天堂av| 国产在线观看免费麻豆| 精品一区二区三区视频日产| 欧美日韩国产一级二级| 一本久道久久久| 免费在线观看黄| 欧美在线激情| 日韩欧美国产一区二区在线播放| 美女久久一区| 激情黄产视频在线免费观看| 国产欧美自拍视频| 色视频www在线播放国产成人 | 免费在线观看91| 欧美一级理论片| 日产国产欧美视频一区精品| 2018av在线| 日本wwwcom| 欧美第一页在线| 17c精品麻豆一区二区免费| 成人台湾亚洲精品一区二区 | 欧美精品国产精品日韩精品| 日本一区免费视频| 亚洲人成网77777色在线播放| 国产呻吟对白刺激无套视频在线| 亚洲影院污污.| 91精品国产色综合久久不卡蜜臀 | 久久精品日韩| 日韩精品中文字幕有码专区| 成人亚洲精品久久久久软件| 99国产精品免费网站| 在线视频国产福利| 久久国产精品99久久久久久丝袜| 亚洲精品一线二线三线| 91在线观看地址| 欧美日韩一区二区综合| 亚洲麻豆精品| 老子影院午夜伦不卡大全| 午夜伦理精品一区| 日本久久精品电影| 国产美女精品在线| 日本在线中文字幕一区| 成人福利在线| 69sex久久精品国产麻豆| 欧美中文在线观看国产| 欧美视频在线一区二区三区 | 国产精品三级久久久久三级| 日韩中字在线| 国产网站在线| 成人网18免费看| 精品一区二区视频| 欧美精品一区二区三区国产精品| 欧美日韩国产中文字幕 | 国产女同性恋一区二区| 91tv官网精品成人亚洲| 亚洲性受xxx喷奶水| 91p在线观看| 一区二区三区四区欧美日韩| 久久久久久久一区二区| 欧美日韩国产一级| 久久久久9999亚洲精品| 黑丝一区二区三区| 中文无码日韩欧| 超碰免费在线播放| 亚洲欧美国产日韩综合| 欧美日韩精品免费看| 69av成年福利视频| 日韩风俗一区 二区| 午夜av电影一区| 91玉足脚交白嫩脚丫在线播放| 国产欧美精品|