国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

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

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

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

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

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

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

本文介紹在寫c++插件時,簡單又常用的寫法,其實本質上,寫插件的難處在于底層的能力和對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. // 定義一個工具函數,生成seq 
  23. void GenSeq(const FunctionCallbackInfo<Value>& args) { 
  24.     Isolate* isolate = args.GetIsolate(); 
  25.     args.GetReturnValue().Set(Number::New(isolate, ++seq)); 
  26.  
  27.  
  28. // 定義一個加法函數 
  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.   // 新建一個函數模版 
  43.   Local<FunctionTemplate> func = FunctionTemplate::New(isolate); 
  44.   // 新建一個字符串表示函數名 
  45.   Local<String> zaylee = String::NewFromUtf8(isolate, "zaylee", v8::NewStringType::kNormal).ToLocalChecked(); 
  46.   // 設置函數名 
  47.   func->SetClassName(zaylee); 
  48.   // 設置原型屬性 
  49.   func->PrototypeTemplate()->Set(isolate, "protoField", Number::New(isolate, 1)); 
  50.   // 設置對象屬性 
  51.   func->InstanceTemplate()->Set(isolate, "instanceField", Number::New(isolate, 2)); 
  52.   func->InstanceTemplate()->Set(isolate, "add", FunctionTemplate::New(isolate, Add)); 
  53.   // 設置函數對象本身的屬性 
  54.   func->Set(isolate, "funcField", Number::New(isolate, 3)); 
  55.   // 根據函數模版創建一個函數 
  56.   Local<Function> ret = func->GetFunction(context).ToLocalChecked(); 
  57.   Local<String> Demo = String::NewFromUtf8(isolate, "Demo", v8::NewStringType::kNormal).ToLocalChecked(); 
  58.   // 導出函數 
  59.   exports->Set(context, Demo, ret).Check(); 
  60.   // 導出工具函數 
  61.   NODE_SET_METHOD(exports, "genSeq", GenSeq); 
  62.  
  63.  
  64. NODE_MODULE_CONTEXT_AWARE(NODE_GYP_MODULE_NAME, Initialize) 
  65.  
  66.  
  67. }  // namespace demo 

寫個測試例子

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

最后編寫編譯配置

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

看起來非常簡單,大概的流程如下

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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色屁屁影院| 国产精品美女久久久久久免费 | 亚洲va国产va天堂va久久 | 久久久久无码国产精品一区 | 国产精品综合一区二区 | 综合在线视频 | 人人干天天干 | 少妇精品久久久久久久久久 | 亚洲精品片 | 国产精品美女久久久久久久网站 | 新久久久久久 | 亚洲一区在线日韩在线深爱 | 国产成人一区二区三区在线观看 | 久久国产精品电影 | 九九热精品在线 | 欧美一区二区三区精品 | 国产综合久久久 | 亚洲成人三级 | 久久综合久久综合久久 | 国产资源在线观看视频 | www久久精品 | 久久精品无码一区二区日韩av | 日本久久久久久 | 久久国产日韩 | 欧美日韩亚洲高清 | 日韩精品免费在线观看 | 在线色综合 | 美日韩一区二区 | 精品成人av | 国外精品久久久蜜桃免费全文阅读 | www.99精品| 精品久久久久久久久久久久 | 亚洲一区二区三区在线播放 | 国产精品久久国产精品 | 中文字幕色 | 国产99久久精品一区二区永久免费 | 97久久超碰 | 一区二区国产精品 | 欧美亚洲高清 | av免费一区二区 | 日本视频在线播放 |