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

聊聊 JS 斷點的實現(xiàn)

開發(fā) 前端
JS 斷點的功能相信大家都用過,當我們設(shè)置一個斷點,然后代碼執(zhí)行到這個斷點時,線程就會停住,然后我們點擊下一步的時候,又會再下一個斷點停住。那么這個停住到底意味著什么呢?下面這個圖是執(zhí)行到一個斷點時 Node.js 的調(diào)用棧。

斷點的實現(xiàn)非常復(fù)雜,這里并不是說要長篇大論講解 JS 斷點在 V8 中是如何實現(xiàn)的,而是想從宏觀上聊一下斷點的實現(xiàn)。這個問題來源于最近和同事討論的關(guān)于 V8 Inspector 實現(xiàn)的一些事情。

JS 斷點的功能相信大家都用過,當我們設(shè)置一個斷點,然后代碼執(zhí)行到這個斷點時,線程就會停住,然后我們點擊下一步的時候,又會再下一個斷點停住。那么這個停住到底意味著什么呢?下面這個圖是執(zhí)行到一個斷點時 Node.js 的調(diào)用棧。

圖片

我們知道 V8 有一個調(diào)試協(xié)議,客戶端是和 V8 通過這個協(xié)議通信完成調(diào)試的,當 V8 收到客戶端的信息并且處理完之后,就會調(diào)用 runMessageLoopOnPause。runMessageLoopOnPause 是 V8 提供的一個約定的 API,當執(zhí)行到 JS 斷點時就會調(diào)用,具體在 runMessageLoopOnPause 里做什么事情由 V8 的使用方實現(xiàn)。在看實現(xiàn)之前,先來思考一下,應(yīng)該怎么處理。首先執(zhí)行到了 JS 斷點,顯然線程就要進入停住的狀態(tài),那么這個停住的狀態(tài)具體是指什么,應(yīng)該怎么實現(xiàn)是一個最關(guān)鍵的問題。這個事件循環(huán)的實現(xiàn)有點類似,那就是當線程沒有任務(wù)處理的時候,它應(yīng)該在做什么,輪詢顯然太不可思議了,那另一種就是基于訂閱 / 發(fā)布機制實現(xiàn)睡眠 / 喚醒,比如 Node.js 基于事件驅(qū)動模塊實現(xiàn)了睡眠 / 喚醒機制。類似的 Inspector 也是這樣實現(xiàn),但是具體細節(jié)不一樣,因為如果情況不一樣,當 Node.js 處于事件循環(huán)的阻塞狀態(tài)時,任何注冊到事件驅(qū)動模塊的事件都可以喚醒 Node.js,但是斷點不一樣,當線程處于斷點時,除了信號外,一般的任務(wù),比如文件 IO、網(wǎng)絡(luò) IO 等,是不能也不應(yīng)該能喚醒線程的,所以這里使用的是簡單的睡眠 / 喚醒方式,那就是條件變量。當線程阻塞于條件變量時,只有通過該條件變量才能喚醒線程。回到斷點的場景,那就是客戶端繼續(xù)執(zhí)行時才能喚醒線程。

分析完之后,來看看 Node.js 的實現(xiàn)。

void runMessageLoopOnPause(int context_group_id) override {
waiting_for_resume_ = true;
runMessageLoop();
}

void runMessageLoop() {
if (running_nested_loop_)
return;

running_nested_loop_ = true;

while (shouldRunMessageLoop()) {
if (interface_) interface_->WaitForFrontendEvent();
env_->RunAndClearInterrupts();
}
running_nested_loop_ = false;
}

重點在 WaitForFrontendEvent。

bool MainThreadInterface::WaitForFrontendEvent() {
dispatching_messages_ = false;
// 任務(wù)隊列為空則阻塞
if (dispatching_message_queue_.empty()) {
Mutex::ScopedLock scoped_lock(requests_lock_);
while (requests_.empty()) incoming_message_cond_.Wait(scoped_lock);
}
return true;
}

我們假設(shè)這時候隊列為空,那么線程就會阻塞在條件變量 incoming_message_cond_ 中。接下來看看如聊聊第二個問題。線程這時候阻塞了,那么客戶端點擊執(zhí)行下一步的時候,Node.js 還還怎么處理?這里就需要子線程幫忙了,所以 Node.js 中,和客戶端的數(shù)據(jù)通信是在子線程完成的,不講太多代碼和細節(jié),直接看一個調(diào)用棧。

圖片

這是客戶端和 Node.js 子線程建立 websocket 連接成功后的調(diào)用棧,后續(xù)的數(shù)據(jù)通信也是類似。來看一下 Post。

void MainThreadInterface::Post(std::unique_ptr<Request> request) {
Mutex::ScopedLock scoped_lock(requests_lock_);
bool needs_notify = requests_.empty();
requests_.push_back(std::move(request));
if (needs_notify) {
std::weak_ptr<MainThreadInterface> weak_self {shared_from_this()};
agent_->env()->RequestInterrupt([weak_self](Environment*) {
if (auto iface = weak_self.lock()) iface->DispatchMessages();
});
}
incoming_message_cond_.Broadcast(scoped_lock);
}

這里看到了剛才熟悉的數(shù)據(jù)結(jié)構(gòu),Post 就是往主線程中插入一個任務(wù),然后喚醒主線程。接著回到 runMessageLoop。

while (shouldRunMessageLoop()) {
if (interface_) interface_->WaitForFrontendEvent();
env_->RunAndClearInterrupts();
}

WaitForFrontendEvent 執(zhí)行完畢后,接著執(zhí)行 RunAndClearInterrupts,RunAndClearInterrupts 正是處理 RequestInterrupt 插入的任務(wù)的。剛才插入任務(wù)時我們看到插入了兩個任務(wù) agent_->env()->RequestInterrupt 和 requests_.push_back(std::move(request)) ,RequestInterrupt 插入的任務(wù)中會調(diào)用 DispatchMessages,而 DispatchMessages 就是處理 requests_ 中的任務(wù)的。

void MainThreadInterface::DispatchMessages() {
dispatching_messages_ = true;
bool had_messages = false;
do {
if (dispatching_message_queue_.empty()) {
Mutex::ScopedLock scoped_lock(requests_lock_);
requests_.swap(dispatching_message_queue_);
}
had_messages = !dispatching_message_queue_.empty();
while (!dispatching_message_queue_.empty()) {
MessageQueue::value_type task;
std::swap(dispatching_message_queue_.front(), task);
dispatching_message_queue_.pop_front();

v8::SealHandleScope seal_handle_scope(agent_->env()->isolate());
task->Call(this);
}
} while (had_messages);
dispatching_messages_ = false;
}

執(zhí)行任務(wù)的時候,具體做的事情就是把客戶端傳過來的數(shù)據(jù)投傳給 V8 Inspector,如果又執(zhí)行到了一個斷點,那么繼續(xù)本文分析到這個邏輯,否則線程就可以繼續(xù)跑了。

責任編輯:武曉燕 來源: 編程雜技
相關(guān)推薦

2022-09-30 00:03:03

JS斷點線程

2017-04-19 10:25:01

JS斷點調(diào)試

2024-12-23 15:05:29

2021-11-06 18:40:27

js底層模塊

2021-09-26 05:06:04

Node.js模塊機制

2022-03-26 16:51:27

Node.jstrace架構(gòu)

2024-05-31 09:31:00

2022-02-18 08:26:12

TopK數(shù)組面試題

2021-07-14 14:05:24

Fragment項目結(jié)構(gòu)

2021-10-04 19:49:23

HTTP模塊No.js

2022-05-27 07:01:48

JSGIF總幀數(shù)

2017-08-08 08:45:44

前端文件斷點續(xù)傳

2022-05-13 09:05:37

JSObject無序

2023-05-26 08:24:17

短信渠道模型

2017-03-06 16:51:52

Java泛型實現(xiàn)

2022-08-05 08:27:05

分布式系統(tǒng)線程并發(fā)

2023-01-26 00:59:39

B-Treegolang度量衡

2025-04-24 00:00:00

Spring AI流式輸出AI 模型

2024-05-13 08:04:26

Vue.jsWeb應(yīng)用程序

2024-04-07 08:23:01

JS隔離JavaScript
點贊
收藏

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

亚洲女成人图区| 国产另类自拍| av有码在线观看| 一区二区国产盗摄色噜噜| 成年人免费观看的视频| 一区二区三区国产在线| 国产精品久久久久久久久久| 97一区二区国产好的精华液| 久久精品99国产精品酒店日本| av手机在线观看| 欧美一级艳片视频免费观看| 阿v免费在线观看| 欧美性猛交xxxx乱大交| 在线观看午夜看亚太视频| 亚洲一区二区三区中文字幕| www.成人精品免费网站青椒| 国产视频一区在线播放| 中文字幕日本最新乱码视频| www.亚洲色图.com| 国产爆乳无码一区二区麻豆| 国产·精品毛片| 国产乱子伦农村叉叉叉| 91视视频在线直接观看在线看网页在线看| 91精品国产吴梦梦| 成人av中文字幕| 777久久久精品一区二区三区 | 亚洲国产一区自拍| 欧美寡妇性猛交xxx免费| 亚洲成人av片在线观看| 性欧美freesex顶级少妇| 日韩乱码在线视频| 成人国产精品| 久久久久久97| 欧美大片aaaa| 国产伦精品一区二区三区免| 老鸭窝91久久精品色噜噜导演| 天堂一区二区三区| 激情综合色播五月| 日本免费不卡一区二区| 亚洲少妇中出一区| 黄色网址在线播放| 亚洲а∨天堂久久精品喷水| 天堂综合在线播放| 欧美在线视频网| 激情综合在线| 欧美 亚洲 视频| 国产精品美日韩| 欧美色视频免费| 亚洲精品国偷自产在线99热| 欧美9999| 国产精品久久久久久久久久直播| 久久99精品久久久久久久久久久久| av动漫在线看| 精品久久久久久国产91| 蜜臀av国内免费精品久久久夜夜| 神马国产精品影院av| 91成人入口| 电影午夜精品一区二区三区| 日韩av电影免费观看高清完整版| 亚洲美免无码中文字幕在线| 亚洲一区二区在线免费看| 国产精品剧情一区二区在线观看| 一区二区三区四区精品| av中文一区| 日本一区不卡| 国产精品污网站| 国产系列在线观看| 久久久国产精品免费| 午夜激情久久| 免费无码毛片一区二三区| 欧美性黄网官网| 素人一区二区三区| 91嫩草在线视频| 91在线视频免费91| 久草资源在线观看| 欧美亚洲在线观看| 精品无码三级在线观看视频| 国产在线传媒| 久久这里有精品| 日韩在线观看一区二区| 久久.com| 亚洲欧洲在线观看| 韩日欧美一区| mm1313亚洲国产精品无码试看| 欧美天堂亚洲电影院在线播放| 成人动漫视频在线观看| 免费不卡亚洲欧美| 国产精品国产自产拍高清av | 蜜桃精品视频| 国产经品一区二区| 中文字幕在线观看一区二区| 国产v日韩v欧美v| 91老司机精品视频| 久久精品欧美日韩| 2018av在线| 国产精品视频免费观看| 亚洲三级久久久| 青青草国产一区二区三区| 日本高清视频一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了| 周于希免费高清在线观看| 成人在线观看网址| 一区二区三区**美女毛片| 国产精品.xx视频.xxtv| 日韩欧美在线电影| 欧美亚洲综合久久| 欧美色婷婷久久99精品红桃| 欧美牲交a欧美牲交aⅴ免费真 | 911国产网站尤物在线观看| 精品一区二区三区香蕉蜜桃| 爱爱爱免费视频在线观看| 日韩av电影免费观看高清| 成人高清视频免费观看| 欧美6一10sex性hd| 亚洲bt天天射| 午夜精品一区二区三区电影天堂| 精品成人18| 欧美激情视频免费看| 精品卡一卡二卡三卡四在线| 亚洲精品黄色| av成人手机在线| 51成人做爰www免费看网站| 亚洲自拍偷拍图区| 黑丝美女一区二区| 男人免费av| 国产日韩欧美成人| 午夜精品一区二区三区三上悠亚| 国产成人黄色| 日本成在线观看| 国产精品人成电影在线观看| 一区二区三区欧美| 日韩午夜电影网| 你懂的视频在线| 成人区精品一区二区| 91高清视频免费看| 伊人久久亚洲影院| 日本在线天堂| 久久综合入口| 日韩一级黄色片| 久88久久88久久久| 日本久久免费| 无码aⅴ精品一区二区三区浪潮 | 成人av免费在线| 国产成人精品一区二区三区视频| 精品久久久无码人妻字幂| 亚洲性生活视频在线观看| 国产99久久久精品| 成人在线视频观看| 少妇高清精品毛片在线视频| 97精品在线观看| 亚洲成av人片www| 欧美三级黄美女| 久草中文在线| 在线观看日韩羞羞视频| 自拍偷拍亚洲在线| 亚洲欧洲色图综合| 欧美搞黄网站| 校园春色亚洲| 国产区二区三区| 国产不卡在线观看| 在线视频中文字幕一区二区| 日韩国产欧美视频| 91成人在线网站| 国产精品粉嫩av| 九色综合日本| 亚洲日本欧美日韩高观看| 国产欧美一区二区在线| 日韩欧美网址| 国产黄色大片在线观看| 日本女优爱爱视频| 亚洲综合成人婷婷小说| 精品视频在线播放色网色视频| 久久久国产午夜精品| 91精品亚洲| 欧美va在线| 一本大道香蕉久久| 亚洲激情一区二区三区| 久久久伊人欧美| 欧美日韩日日摸| av电影一区二区| 五月开心六月丁香综合色啪| 成人免费短视频| 九色porny在线观看| 精品91一区二区三区| 国模视频一区二区| 91成人免费在线| 99国产精品久久| 一级欧洲+日本+国产 | 欧美男女性生活在线直播观看| 国产精品自在在线| 欧美色图国产精品| 国内精彩免费自拍视频在线观看网址| 国产成人黄色网址| 日本一区二区三区www| 96精品视频在线| 亚洲精品在线三区| 亚洲图片欧美综合| 成人激情免费电影网址| 在线日韩欧美| 偷拍亚洲精品|