激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - Nodejs系列之使用V8編寫C++插件

Nodejs系列之使用V8編寫C++插件

2021-04-13 23:56編程雜技theanarkh JavaScript

本文介紹在寫c++插件時(shí),簡(jiǎn)單又常用的寫法,其實(shí)本質(zhì)上,寫插件的難處在于底層的能力和對(duì)libuv、v8的了解。話不多說,直接看代碼。

Nodejs系列之使用V8編寫C++插件

雖然現(xiàn)在大部分情況都是使用n-api來編寫插件,但是底層畢竟是v8(和libuv),使用v8編寫簡(jiǎn)單的插件,同時(shí)熟悉v8的使用。

本文介紹在寫c++插件時(shí),簡(jiǎn)單又常用的寫法,其實(shí)本質(zhì)上,寫插件的難處在于底層的能力和對(duì)libuv、v8的了解。話不多說,直接看代碼。

  1. #include <node.h> 
  2.  
  3.  
  4. namespace demo { 
  5.  
  6.  
  7. using v8::FunctionCallbackInfo; 
  8. using v8::Isolate; 
  9. using v8::Local
  10. using v8::Object; 
  11. using v8::String; 
  12. using v8::Value; 
  13. using v8::FunctionTemplate; 
  14. using v8::Function
  15. using v8::Number; 
  16. using v8::MaybeLocal; 
  17. using v8::Context; 
  18. using v8::Int32; 
  19.  
  20.  
  21. static int seq; 
  22. // 定義一個(gè)工具函數(shù),生成seq 
  23. void GenSeq(const FunctionCallbackInfo<Value>& args) { 
  24.     Isolate* isolate = args.GetIsolate(); 
  25.     args.GetReturnValue().Set(Number::New(isolate, ++seq)); 
  26.  
  27.  
  28. // 定義一個(gè)加法函數(shù) 
  29. void Add(const FunctionCallbackInfo<Value>& args) { 
  30.     Isolate* isolate = args.GetIsolate(); 
  31.     int a = args[0].As<Int32>()->Value(); 
  32.     int b = args[1].As<Int32>()->Value(); 
  33.     args.GetReturnValue().Set(Number::New(isolate, a + b)); 
  34.  
  35.  
  36. void Initialize( 
  37.   Local<Object> exports, 
  38.   Local<Value> module, 
  39.   Local<Context> context 
  40. ) { 
  41.   Isolate* isolate = context->GetIsolate(); 
  42.   // 新建一個(gè)函數(shù)模版 
  43.   Local<FunctionTemplate> func = FunctionTemplate::New(isolate); 
  44.   // 新建一個(gè)字符串表示函數(shù)名 
  45.   Local<String> zaylee = String::NewFromUtf8(isolate, "zaylee", v8::NewStringType::kNormal).ToLocalChecked(); 
  46.   // 設(shè)置函數(shù)名 
  47.   func->SetClassName(zaylee); 
  48.   // 設(shè)置原型屬性 
  49.   func->PrototypeTemplate()->Set(isolate, "protoField", Number::New(isolate, 1)); 
  50.   // 設(shè)置對(duì)象屬性 
  51.   func->InstanceTemplate()->Set(isolate, "instanceField", Number::New(isolate, 2)); 
  52.   func->InstanceTemplate()->Set(isolate, "add", FunctionTemplate::New(isolate, Add)); 
  53.   // 設(shè)置函數(shù)對(duì)象本身的屬性 
  54.   func->Set(isolate, "funcField", Number::New(isolate, 3)); 
  55.   // 根據(jù)函數(shù)模版創(chuàng)建一個(gè)函數(shù) 
  56.   Local<Function> ret = func->GetFunction(context).ToLocalChecked(); 
  57.   Local<String> Demo = String::NewFromUtf8(isolate, "Demo", v8::NewStringType::kNormal).ToLocalChecked(); 
  58.   // 導(dǎo)出函數(shù) 
  59.   exports->Set(context, Demo, ret).Check(); 
  60.   // 導(dǎo)出工具函數(shù) 
  61.   NODE_SET_METHOD(exports, "genSeq", GenSeq); 
  62.  
  63.  
  64. NODE_MODULE_CONTEXT_AWARE(NODE_GYP_MODULE_NAME, Initialize) 
  65.  
  66.  
  67. }  // namespace demo 

寫個(gè)測(cè)試?yán)?/p>

  1. const { Demo, genSeq } = require('./build/Release/test.node'); 
  2. const demo = new Demo(); 
  3. console.log('demo對(duì)象:', demo, '\n'); 
  4. console.log('原型屬性:', demo.protoField, '\n'); 
  5. console.log('執(zhí)行add方法:', demo.add(1,2), '\n');   
  6. console.log('執(zhí)行seq方法:', genSeq(), genSeq(), '\n'); 

最后編寫編譯配置

  1. {   
  2. "targets": [   
  3.   {   
  4.     "target_name""test",   
  5.     "sources": [ "./test.cc" ]   
  6.   }   
  7. ]   

看起來非常簡(jiǎn)單,大概的流程如下

  1. npm install -g node-gyp 
  2. node-gyp configure 
  3. node-gyp build 
  4. node test.js 

拓展nodejs的方式很多,插件是一種,直接修改內(nèi)核也是一種,之前有介紹過如何修改內(nèi)核,有興趣的同學(xué)也可以看一下。

原文地址:https://mp.weixin.qq.com/s/oJDHYoPuCR7iy7XGp6eHTw

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲免费网站 | 国产成人在线网站 | 亚洲片在线观看 | 精品国产91久久久久 | 欧美不卡 | av在线收看| 国产亚洲欧美日韩在线观看不卡 | 亚洲天堂成人在线观看 | 草草久 | 欧美aⅴ在线观看 | 91九色丨porny丨国产jk | 一级精品 | 91丝袜| 一级黄片毛片免费看 | 国产精品69久久 | 国产女做a爱免费视频 | 亚洲电影免费观看国语版 | 日本网站在线看 | 97中文字幕第一一一页 | 激情小说激情图片激情电影 | a网站在线 | 久色网站 | 亚洲乱妇19p | 国产精品资源手机在线播放 | 免费嗨片首页中文字幕 | 中文欧美日韩 | 久久艹艹艹 | 自拍偷拍亚洲图片 | 91丝袜| 欧美人人干| 欧美在线小视频 | 色网站在线免费观看 | 99爱视频在线观看 | 成人在线精品视频 | 91网视频在线观看 | 国产色片 | 国产一国产一级毛片视频 | 国语自产免费精品视频在 | 欧美日韩国产一区二区三区在线观看 | 成人区一区二区三区 | 日韩精品无码一区二区三区 |