虽然现在大部分情况都是使用n-api来编写插件,但是底层毕竟是v8(和libuv),使用v8编写简单的插件,同时熟悉v8的使用。

为岳塘等地区用户提供了全套网页设计制作服务,及岳塘网站建设行业解决方案。主营业务为成都做网站、成都网站设计、成都外贸网站建设、岳塘网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
本文介绍在写c++插件时,简单又常用的写法,其实本质上,写插件的难处在于底层的能力和对libuv、v8的了解。话不多说,直接看代码。
- #include
 - namespace demo {
 - using v8::FunctionCallbackInfo;
 - using v8::Isolate;
 - using v8::Local;
 - using v8::Object;
 - using v8::String;
 - using v8::Value;
 - using v8::FunctionTemplate;
 - using v8::Function;
 - using v8::Number;
 - using v8::MaybeLocal;
 - using v8::Context;
 - using v8::Int32;
 - static int seq;
 - // 定义一个工具函数,生成seq
 - void GenSeq(const FunctionCallbackInfo
 & args) { - Isolate* isolate = args.GetIsolate();
 - args.GetReturnValue().Set(Number::New(isolate, ++seq));
 - }
 - // 定义一个加法函数
 - void Add(const FunctionCallbackInfo
 & args) { - Isolate* isolate = args.GetIsolate();
 - int a = args[0].As
 ()->Value(); - int b = args[1].As
 ()->Value(); - args.GetReturnValue().Set(Number::New(isolate, a + b));
 - }
 - void Initialize(
 - Local
 - Local
 module, - Local
 context - ) {
 - Isolate* isolate = context->GetIsolate();
 - // 新建一个函数模版
 - Local
 func = FunctionTemplate::New(isolate); - // 新建一个字符串表示函数名
 - Local
 zaylee = String::NewFromUtf8(isolate, "zaylee", v8::NewStringType::kNormal).ToLocalChecked(); - // 设置函数名
 - func->SetClassName(zaylee);
 - // 设置原型属性
 - func->PrototypeTemplate()->Set(isolate, "protoField", Number::New(isolate, 1));
 - // 设置对象属性
 - func->InstanceTemplate()->Set(isolate, "instanceField", Number::New(isolate, 2));
 - func->InstanceTemplate()->Set(isolate, "add", FunctionTemplate::New(isolate, Add));
 - // 设置函数对象本身的属性
 - func->Set(isolate, "funcField", Number::New(isolate, 3));
 - // 根据函数模版创建一个函数
 - Local
 ret = func->GetFunction(context).ToLocalChecked(); - Local
 Demo = String::NewFromUtf8(isolate, "Demo", v8::NewStringType::kNormal).ToLocalChecked(); - // 导出函数
 - exports->Set(context, Demo, ret).Check();
 - // 导出工具函数
 - NODE_SET_METHOD(exports, "genSeq", GenSeq);
 - }
 - NODE_MODULE_CONTEXT_AWARE(NODE_GYP_MODULE_NAME, Initialize)
 - } // namespace demo
 
写个测试例子
- const { Demo, genSeq } = require('./build/Release/test.node');
 - const demo = new Demo();
 - console.log('demo对象:', demo, '\n');
 - console.log('原型属性:', demo.protoField, '\n');
 - console.log('执行add方法:', demo.add(1,2), '\n');
 - console.log('执行seq方法:', genSeq(), genSeq(), '\n');
 
最后编写编译配置
- {
 - "targets": [
 - {
 - "target_name": "test",
 - "sources": [ "./test.cc" ]
 - }
 - ]
 - }
 
看起来非常简单,大概的流程如下
- npm install -g node-gyp
 - node-gyp configure
 - node-gyp build
 - node test.js
 
拓展nodejs的方式很多,插件是一种,直接修改内核也是一种,之前有介绍过如何修改内核,有兴趣的同学也可以看一下。
                网站名称:Nodejs系列之使用V8编写C++插件
                
                网站路径:http://www.csdahua.cn/qtweb/news30/291030.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网