精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Node.js ObjectWrap 的弱引用問題

開發 前端
最近在寫 Node.js Addon 的過程中,遇到了一個問題,然后發現是 ObjectWrap 弱引用導致的,本文介紹一下具體的問題和排查過程,以及 ObjectWrap 的使用問題。

前言:最近在寫 Node.js Addon 的過程中,遇到了一個問題,然后發現是 ObjectWrap 弱引用導致的,本文介紹一下具體的問題和排查過程,以及 ObjectWrap 的使用問題。

ObjectWrap 用于寫 Addon 的時候導出 C++ 對象給 JS 層使用,大致用法如下。首先定義一個 C++ 類。

  1. class Demo: public node::ObjectWrap { 
  2.      public
  3.          static void create(const FunctionCallbackInfo<Value>& args) { 
  4.                     new Demo(args.This()); 
  5.          } 
  6.          Demo(Local<Object> object): node::ObjectWrap() {} 
  7.      private: 
  8.         uv_timer_t timer; 
  9.  
  10. }; 

然后導出這個類到 JS。

  1. void Initialize( 
  2.   Local<Object> exports, 
  3.   Local<Value> module, 
  4.   Local<Context> context 
  5. ) { 
  6.   Isolate *isolate = context->GetIsolate(); 
  7.   Local<FunctionTemplate> demo = FunctionTemplate::New(isolate, Demo::create); 
  8.   char * str = "Demo"
  9.   Local<String> name = String::NewFromUtf8(isolate, str, NewStringType::kNormal, strlen(str)).ToLocalChecked(); 
  10.   demo->InstanceTemplate()->SetInternalFieldCount(1); 
  11.   exports->Set(context, name, demo->GetFunction(context).ToLocalChecked()).Check(); 
  12.  
  13.  
  14. NODE_MODULE_CONTEXT_AWARE(NODE_GYP_MODULE_NAME, Initialize) 

然后在 JS 通過以下方式調用。

 

  1. const { Demo } = require('demo.node'); 
  2.  
  3. const demo = new Demo(); 

可以看到 C++ Demo 類中有一個 uv_timer_t 成員。主要用來定時去抓取 V8 堆快照,所以把它注冊到 Libuv 中。

 

  1. uv_timer_init(loop, &timer); 
  2.  
  3. uv_timer_start(&timer, timer_cb, 1000, 1000); 

然后使用的過程中我們發現,定時器隨機觸發了幾次后,就不觸發了。經過多種測試無果后,我不得不編譯一個 debug 版本的 Node.js 進行單步調試,然后就發現了有意思的事情。第一次進入 poll io 階段時,一切正常,1 秒后超時。

 

 

 

 

但是后面再次進入 poll io 階段時,詭異的事情發生了。

 

 

 

 

超時時間變成了一個很大的數字,正常來說,我設置的每隔一秒超時一次,這里應該是 1才對,為什么會出現一個詭異的數字呢。思考了一下,猜想是這塊內存被釋放了,然后里面保存了一些臟數據,接著我給 Demo 類加了個析構函數。

 

  1. ~Demo() { 
  2.   LOG("dead"); 
  3.  

然后發現,這個類對象居然被析構了。通過棧追蹤發現邏輯來自于 ObjectWrap 的 WeakCallback。

 

 

 

 

WeakCallback 的代碼如下。

  1. static void WeakCallback(const v8::WeakCallbackInfo<ObjectWrap>& data) { 
  2.    ObjectWrap* wrap = data.GetParameter(); 
  3.    wrap->handle_.Reset(); 
  4.    delete wrap; 
  5.  

delete wrap 就是 delete 了 Demo 對象。而這個 WeakCallback 的源頭來自 ObjectWrap 的 MakeWeak。

  1. inline void MakeWeak() { 
  2.     persistent().SetWeak(this, WeakCallback, v8::WeakCallbackType::kParameter); 

這個 MakeWeak 又來源于 Wrap。

  1. inline void Wrap(v8::Local<v8::Object> handle) { 
  2.     // 關聯 C++ 對象和 Demo 對象 
  3.     handle->SetAlignedPointerInInternalField(0, this); 
  4.     persistent().Reset(v8::Isolate::GetCurrent(), handle); 
  5.     MakeWeak(); 
  6.  

Wrap 是創建 Demo 對象時調用的函數。用于關聯 JS 層對象和 C++ 對象,關系如下。

 

 

 

 

所以 JS 創建一個 Demo 對象的時候,就會指向一個 C++ 對象,然后 Demo 對象也有個持久句柄指向這個 C++ 對象。但是它默認情況下調用了 MakeWeak,也就是弱引用。而 JS 層在創建完 Demo 對象后就離開了作用域,因為 JS 模塊是被函數包裹起來的,執行完變量就被 gc了,除非通過 module.exports 或全局變量保持對 C++ 對象的引用。所以就導致了 C++ 對象最終被 Demo 對象以弱引用的方式引用著,等待 gc 的時候被回收。這里又引出了另一個問題,當我把抓取快照的代碼改成一些簡單的代碼時,并不容易觸發這個問題,原因在于它沒有觸發 gc。后來我嘗試在 JS 層分配一些內存,最終也成功觸發了這個問題,因為下面的代碼會導致 gc。而 gc 的時候就把 C++ 對象回收了。

 

  1. setInterval(() => { 
  2.     Buffer.from('x'.repeat('10')) 
  3.  
  4. },3000) 

這個問題的解決方式就是調用 ObjectWrap 的 Ref 函數消除弱引用(或者在 JS 層保持對這個對象的引用)。

 

  1. virtual void Ref() { 
  2.     persistent().ClearWeak(); 
  3.     refs_++; 

回過頭來看看 Node.js 中另一個類似功能的類 BaseObject。

  1. BaseObject::BaseObject(Environment* env, v8::Local<v8::Object> object) 
  2.     : persistent_handle_(env->isolate(), object), env_(env) { 
  3.   object->SetAlignedPointerInInternalField(BaseObject::kSlot, static_cast<void*>(this)); 
  4.  

它并沒有設置弱引用的邏輯。所以在 Node.js 的 C++ 模塊里,我們也看不到主動調用 Ref 的代碼。這或許是使用 ObjectWrap 時需要注意的問題。

 

 

 

總結:大致分析了 ObjectWrap 相關的這個問題,但是其實排查過程比描述的繁瑣和困難,主要是一開始沒有用 debug 版本的 Node.js 進行調試,把排查聚焦在打快照的地方了,因為那里涉及了多線程操作同一個 isolate,所以以為是 V8 API 使用方式的問題。總的來說,如果碰到 Node.js 詭異的一些問題,不妨打個 debug 版本的 Node.js 進行調試,可能會更快地找到問題,從中也能學到很多東西。

 

責任編輯:姜華 來源: 編程雜技
相關推薦

2017-04-10 13:28:32

Node.jsJavaScript

2023-06-30 23:25:46

HTTP模塊內存

2022-06-23 06:34:56

Node.js子線程

2025-01-08 08:47:44

Node.js內存泄露定時器

2013-11-01 09:34:56

Node.js技術

2015-03-10 10:59:18

Node.js開發指南基礎介紹

2025-10-15 00:26:20

2021-12-25 22:29:57

Node.js 微任務處理事件循環

2020-05-29 15:33:28

Node.js框架JavaScript

2012-02-03 09:25:39

Node.js

2011-11-01 10:30:36

Node.js

2011-09-08 13:46:14

node.js

2011-09-02 14:47:48

Node

2011-09-09 14:23:13

Node.js

2012-10-24 14:56:30

IBMdw

2011-11-10 08:55:00

Node.js

2025-07-21 01:00:00

UDP性能QPS

2021-09-26 05:06:04

Node.js模塊機制

2021-11-06 18:40:27

js底層模塊

2011-11-02 09:04:15

Node.js
點贊
收藏

51CTO技術棧公眾號

日韩精品福利在线| 亚洲免费视频中文字幕| 欧美在线激情视频| 中文字幕网站在线观看| 国产不卡网站| 中文字幕一区在线观看视频| 色欧美日韩亚洲| 好吊妞www.84com只有这里才有精品| 日本高清www免费视频| 蜜桃精品噜噜噜成人av| 欧美日韩在线不卡| www.一区二区.com| 成人久久精品人妻一区二区三区| 国产亚洲成人一区| 日韩中文字幕精品| 中文字幕一区二区人妻电影丶| 午夜精品成人av| 亚洲激情欧美激情| 免费看成人片| 国产成人av免费看| 老鸭窝91久久精品色噜噜导演| 色久欧美在线视频观看| 天堂www中文在线资源| 国产毛片精品久久| 精品久久香蕉国产线看观看gif| 亚洲一区二区高清视频| 亚洲人妻一区二区三区| 韩国av一区二区三区| 国产91精品久久久久久| av激情在线观看| 国产一区二区三区四区大秀| 精品国产一区二区亚洲人成毛片| 一级片视频免费观看| 超碰在线公开| 中文字幕在线不卡一区二区三区| 美女精品国产| 色婷婷中文字幕| 国产精品99久久久久久宅男| 国产精品日韩精品| 五月天婷婷导航| 亚洲视频久久| 久久久精品亚洲| 性欧美一区二区| 网曝91综合精品门事件在线| 精品成人a区在线观看| 成年人网站av| 欧美日韩va| 91福利区一区二区三区| 欧美 丝袜 自拍 制服 另类| 日本aa在线| 亚洲精品你懂的| 日韩国产在线一区| 黄色小视频在线免费观看| hitomi一区二区三区精品| av日韩中文字幕| av官网在线观看| 激情伊人五月天久久综合| 国产精品欧美一区二区| 伊人久久中文字幕| 日韩福利电影在线观看| 国产精品久久久久久五月尺| 久久久精品视频网站| 久久国产欧美| 国产精品吹潮在线观看| 最近中文在线观看| 麻豆精品蜜桃视频网站| 国产精品一二三在线| 中文字幕福利视频| 久久国产精品第一页| 国产精品主播视频| 97在线播放免费观看| 国产精品综合一区二区| 国产精品免费区二区三区观看| 亚洲毛片欧洲毛片国产一品色| 国产一二三精品| 99精彩视频在线观看免费| av中文字幕免费| 懂色av一区二区夜夜嗨| 精品国产乱码久久久久| 精品欧美不卡一区二区在线观看| 国产日产欧美一区二区三区| 亚洲毛片aa| 黄在线免费看| 亚洲亚洲精品在线观看| 女人和拘做爰正片视频| 日韩高清在线| 91精品免费观看| 中国一级特黄录像播放| 狠狠操综合网| 九九热精品视频| 黄色大片网站在线观看| 美腿丝袜一区二区三区| 国产福利久久| 黄色在线观看网| 亚洲蜜臀av乱码久久精品蜜桃| 99热久久这里只有精品| 免费电影日韩网站| 91精品国产综合久久精品麻豆 | 欧美亚洲图片小说| www.久久久久久久久久久| 国产毛片久久久| 中文字幕亚洲综合久久筱田步美| 欧美日韩亚洲国产另类| 鲁大师影院一区二区三区| 亚洲va久久久噜噜噜| 亚洲欧洲综合在线| 亚洲美女视频在线| 国产成人无码av在线播放dvd| 国产精品白丝久久av网站| 亚洲国产中文字幕久久网| 成人在线观看免费高清| 亚洲国产mv| 国产在线精品自拍| 日本护士...精品国| 亚洲视频精选在线| 亚洲欧美另类动漫| 久久动漫网址| 九九视频直播综合网| wwwwww在线观看| 99在线精品视频| 路边理发店露脸熟妇泻火| 韩国成人在线| 日韩精品免费观看| 国产一级片久久| 极品少妇xxxx精品少妇| 日韩欧美电影一区二区| 黄频免费在线观看| 欧美成人性战久久| 国产性生活大片| 日本不卡一区二区| 欧美日韩另类丝袜其他| mm视频在线视频| 欧美成人国产一区二区| 糖心vlog免费在线观看| 日韩av中文在线观看| 乱一区二区三区在线播放| heyzo中文字幕在线| 91精品国产综合久久国产大片| 人妻无码一区二区三区免费| 老司机午夜免费精品视频| 精品1区2区| 99爱在线观看| 亚洲国产古装精品网站| 精品视频一区二区在线观看| 国产成人免费网站| 国产免费xxx| 精品一区二区三区中文字幕在线| www.久久久久| 亚洲一级av毛片| 中文字幕一区二区视频| 黄色小视频免费网站| 99精品网站| 亚洲va欧美va国产综合剧情| 菠萝菠萝蜜在线视频免费观看| 欧美一区二区视频观看视频 | 亚洲综合偷拍欧美一区色| 亚洲第一天堂久久| 91视频综合| 亚洲v日韩v综合v精品v| av片在线观看网站| 日韩美女视频一区二区在线观看| 538任你躁在线精品视频网站| 国产精品夜夜嗨| 2018中文字幕第一页| 日本一道高清一区二区三区| 热99在线视频| 9191在线观看| 91精品国产综合久久久久| 九九视频在线免费观看| aaa亚洲精品一二三区| 逼特逼视频在线| av一区二区高清| 成人网中文字幕| 国产美女情趣调教h一区二区| 日韩av在线网页| 天天爽夜夜爽人人爽| 国产精品久久久久久久久快鸭| 亚洲一二区在线观看| 国内激情久久| 欧美亚洲免费高清在线观看| 成人黄色免费网站| 九九热r在线视频精品| 深夜福利在线看| 在线观看日产精品| 精品自拍偷拍视频| av福利精品导航| 欧美日韩在线观看不卡| 欧美成人嫩草网站| 国语精品免费视频| 国产原创一区| 国模私拍视频一区| 成人18在线| 精品女同一区二区| 无码人妻一区二区三区免费| 亚洲另类在线一区| 中文人妻一区二区三区| 久久se精品一区精品二区| 国产日韩欧美精品在线观看| 欧美日韩中文一区二区| 成人av播放| 日韩不卡视频在线观看| 欧美高清视频在线播放| 第一福利在线| 精品国产一区二区三区四区四| 国产精华7777777| 午夜精品久久久久久久99水蜜桃| 五月天婷婷丁香网| 99精品视频一区二区| 亚洲欧美天堂在线| 久久男女视频| 国产天堂视频在线观看| 91亚洲国产| 欧美日本韩国国产| 成人三级av在线| 国产在线98福利播放视频| 成人av观看| 国外视频精品毛片| 精品麻豆一区二区三区| 伊人av综合网| 嫩草研究院在线| 欧美精品一区二区久久久| 国产尤物视频在线观看| 在线观看日韩电影| 日韩不卡在线播放| 午夜婷婷国产麻豆精品| 欧美人禽zoz0强交| 中文字幕在线不卡一区二区三区| 国产免费无遮挡吸奶头视频| 97se亚洲国产综合自在线观| 色诱av手机版| 国产乱码精品一品二品| 欧美日韩精品区别| 日本 国产 欧美色综合| 欧美日韩在线免费播放| 销魂美女一区二区三区视频在线| 日本手机在线视频| 国产综合精品| 欧美人与动牲交xxxxbbbb| 亚洲最新色图| 人人妻人人澡人人爽精品欧美一区| 欧美熟乱15p| 日本在线观看一区| 欧美精美视频| 欧美日韩亚洲一区二区三区在线观看 | 亚洲激情久久| 最新av在线免费观看| 91成人超碰| 免费极品av一视觉盛宴| 欧美特黄一区| 久艹在线免费观看| 99国产成+人+综合+亚洲欧美| 人妻无码久久一区二区三区免费| 亚洲黄色在线| 每日在线更新av| 米奇777在线欧美播放| 无码人妻丰满熟妇区毛片| 丝袜亚洲另类欧美综合| 国产aaaaa毛片| 老鸭窝一区二区久久精品| 国产欧美一区二| 国产精品996| 一级做a爰片毛片| 久久久久久久久岛国免费| 久久精品—区二区三区舞蹈| 国产精品久久久久aaaa| 国产97免费视频| 亚洲国产va精品久久久不卡综合| 日本熟妇毛耸耸xxxxxx| 欧美视频不卡中文| 成人黄色片在线观看| 欧美精品丝袜中出| 亚洲精品97久久中文字幕无码| 亚洲成人a级网| 精品久久av| 久久精品国产96久久久香蕉| 欧美bbbxxxxx| 日韩美女免费视频| 婷婷丁香久久| 国产一区二区三区四区hd| 欧美禁忌电影| 在线观看17c| 久久都是精品| 五月天婷婷在线观看视频| 成人免费精品视频| 欧美黄色高清视频| 一区二区三区免费看视频| 日韩 欧美 综合| 欧美日韩国产一级| 色婷婷激情五月| 日韩视频在线免费| 国产在线看片免费视频在线观看| 国产成人精品日本亚洲| 欧美视频二区欧美影视| 美女一区视频| 欧美精品大片| 欧美三级理论片| 粉嫩嫩av羞羞动漫久久久| 亚洲熟妇一区二区三区| 亚洲男同1069视频| 无码人妻熟妇av又粗又大| 日韩欧美在线123| 国产精品视频二区三区| 欧美精品成人在线| 九九热这里有精品| 久久久久成人精品免费播放动漫| 999国产精品永久免费视频app| 欧美 国产 综合| 国产精品夜夜嗨| 911国产在线| 日韩欧美主播在线| 亚洲第一天堂影院| xxx一区二区| 国产免费不卡| 国产日韩久久| 亚洲欧洲中文字幕| 一道本在线免费视频| 久久夜色精品国产欧美乱极品| 久草视频免费在线播放| 欧美日韩一卡二卡| 国产中文在线视频| 91产国在线观看动作片喷水| 136导航精品福利| 手机成人av在线| 日韩av在线发布| 李宗瑞91在线正在播放| 亚洲高清免费一级二级三级| a网站在线观看| 久久韩国免费视频| 992tv国产精品成人影院| 久久久综合亚洲91久久98| 亚洲午夜视频| 女教师高潮黄又色视频| 国产精品精品国产色婷婷| 波多野结衣在线观看视频| 亚洲男人天堂2024| 欧美私密网站| 国产综合欧美在线看| 极品av少妇一区二区| 亚洲av无码成人精品区| 亚洲伦理在线精品| a级片免费观看| 久久99久久99精品免观看粉嫩| 精品国产乱码一区二区三区| 一区二区在线观| 精品亚洲国产成人av制服丝袜| 免费看一级黄色| 欧美二区三区的天堂| 久久久久久久久免费视频| 91久久久在线| 亚洲成人三区| 亚洲最大视频网| 亚洲国产欧美在线| 神宫寺奈绪一区二区三区| 欧美亚洲视频在线看网址| 亚洲男人都懂第一日本| 成年人小视频网站| 亚洲国产精品av| 国产精品伦理一区| 欧美成人久久久| 国产精品乱战久久久| 91猫先生在线| 中文字幕第一页久久| 91久久精品国产91性色69| 美女精品久久久| 成人影院中文字幕| 国产亚洲综合视频| 国产欧美日韩麻豆91| 国产精品爽爽久久| 久久久成人精品视频| 伊人久久影院| 久草热视频在线观看| 日本一区二区三区国色天香| 国产孕妇孕交大片孕| 国内精品久久久久久| 国产一区二区三区四区五区传媒| 女人高潮一级片| 亚洲高清视频的网址| 奇米精品一区二区三区四区 | 久久只有精品| 性色国产成人久久久精品| 欧美一区二区三区四区视频| 成人av影院在线观看| 欧美一区视久久| 经典一区二区三区| 五月天综合激情| 日韩在线播放一区| 激情小说亚洲图片| 九九热免费精品视频| 一级精品视频在线观看宜春院 | 日本黄色一级视频| xxx欧美精品| 色婷婷久久久| 亚洲欧美日本一区二区三区| 亚洲第一av色| 日韩三级影院| 久久99九九| 精品在线播放午夜| 日韩一区二区视频在线| 超碰97人人做人人爱少妇| 婷婷精品在线|