自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

[[392755]]

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

本文介紹在寫c++插件時,簡單又常用的寫法,其實本質(zhì)上,寫插件的難處在于底層的能力和對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. // 定義一個工具函數(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. // 定義一個加法函數(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.   // 新建一個函數(shù)模版 
  43.   Local<FunctionTemplate> func = FunctionTemplate::New(isolate); 
  44.   // 新建一個字符串表示函數(shù)名 
  45.   Local<String> zaylee = String::NewFromUtf8(isolate, "zaylee", v8::NewStringType::kNormal).ToLocalChecked(); 
  46.   // 設置函數(shù)名 
  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.   // 設置函數(shù)對象本身的屬性 
  54.   func->Set(isolate, "funcField", Number::New(isolate, 3)); 
  55.   // 根據(jù)函數(shù)模版創(chuàng)建一個函數(shù) 
  56.   Local<Function> ret = func->GetFunction(context).ToLocalChecked(); 
  57.   Local<String> Demo = String::NewFromUtf8(isolate, "Demo", v8::NewStringType::kNormal).ToLocalChecked(); 
  58.   // 導出函數(shù) 
  59.   exports->Set(context, Demo, ret).Check(); 
  60.   // 導出工具函數(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 

寫個測試例子

  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('執(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. ]   

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

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

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

 

責任編輯:武曉燕 來源: 編程雜技
相關推薦

2021-08-29 18:34:44

編譯V8C++

2020-09-27 07:32:18

V8

2010-07-20 16:35:52

V8JavaScript瀏覽器

2022-06-02 12:02:12

V8C++JavaScript

2014-11-26 09:51:24

GithubGoogleV8

2023-10-10 10:23:50

JavaScriptV8

2023-03-02 23:09:53

Node.jsC++JS

2020-07-30 12:40:35

CC++編程語言

2023-02-28 07:56:07

V8內(nèi)存管理

2022-09-16 08:32:25

JavaC++語言

2023-06-05 16:38:51

JavaScript編程語言V8

2011-10-19 13:47:57

ibmdwRationalWAS

2016-10-18 15:18:48

JEECMS V*javaCMS系統(tǒng)

2010-01-14 14:40:21

C++代碼

2021-05-28 05:30:55

HandleV8代碼

2011-09-08 10:21:50

Node.js

2022-04-29 08:00:51

V8垃圾回收

2010-08-31 11:42:03

DB2MDC

2017-12-17 16:34:18

JavaScript代碼V8

2022-10-24 09:11:05

TypeScriptV8
點贊
收藏

51CTO技術棧公眾號