Node.js_8.0_N-API_入门极简例子

全文链接

本文摘录自《Nodejs学习笔记》,更多章节及更新,请访问 github主页地址。欢迎加群交流,群号 197339705

N-API简介

Node.js 8.0 在2017年6月份发布,升级的特性中,包含了N-API。编写过或者使用过 node扩展的同学,不少都遇到过升级node版本,node扩展编译失败的情况。因为node扩展严重依赖于V8暴露的API,而node不同版本依赖的V8版本可能不同,一旦升级node版本,原先运行正常的node扩展就编译失败了。

这种情况对node生态圈无疑是不利的,N-API的引入正是试图改善这种情况的一种尝试。它跟底层JS引擎无关,只要N-API暴露的API足够稳定,那么node扩展的编写者就不用过分担忧node的升级问题。

如何使用N-API

先强调一点,N-API并不是对原有node扩展实现方式的替代,它只是提供了一系列底层无关的API,来帮助开发者编写跨版本的node扩展。至于如何编写、编译、使用扩展,跟原来的差不多。

本文会从一个超级简单的例子,简单介绍N-API的使用,包括环境准备、编写扩展、编译、运行几个步骤。

备注:当前N-API还处于试验阶段,官方文档提供的例子都是有问题的,如用于生产环境需格外谨慎。

1、环境准备

首先,N-API是8.0版本引入的,首先确保本地安装了8.0版本。笔者用的是nvm,读者可自行选择安装方式。

nvm i 8.0
nvm use 8.0

然后,安装node-gyp,编译扩展会用到。

npm install -g node-gyp

创建项目目录,并初始化package.json

mkdir hello & cd hello # 目录名随便起
npm init -f

 

转载于:https://my.oschina.net/u/3462387/blog/915482

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一段 C++ 代码,定义了一个名为 ReleaseOneValue 的函数,函数的参数是一个 void 指针 data。以下是每行代码的解释: 1. `void ReleaseOneValue(void* data)`:定义了一个返回类型为 void,参数为 void 指针的函数 ReleaseOneValue。 2. `if (data == NULL) { return; }`:如果传入的参数 data 是空指针,则直接返回,不做任何操作。 3. `ValueNode* node = (ValueNode*)data;`:将参数 data 强制转换为 ValueNode 类型的指针,并将其赋值给变量 node。 4. `if (node->value_.use_count_ <= 1)`:判断 node 的 value_ 成员变量中的 use_count_ 是否小于等于 1。 5. `node->value_.use_count_ = 0;`:将 node 的 value_ 成员变量中的 use_count_ 设置为 0。 6. `node_list_tail_->next_node_ = node;`:将 node 添加到链表 node_list_tail_ 的尾部。 7. `node->next_node_ = NULL;`:将 node 的 next_node_ 成员变量设置为 NULL。 8. `node_list_tail_ = node;`:将 node_list_tail_ 的值更新为 node。 9. `value_status_.free_num_++;`:将 value_status_ 中的 free_num_ 成员变量加 1。 10. `node->value_.RelResourceInTime();`:调用 node 的 value_ 成员变量中的 RelResourceInTime 函数,该函数用于释放动态分配的内存。 11. `if(rphead && ::is_open_reverse)`:如果变量 rphead 不为空且全局变量 ::is_open_reverse 为真,则执行以下操作: 12. `if(PACKET_NONE != rphead->btCurStaus)`:如果 rphead 的 btCurStaus 成员变量不等于 PACKET_NONE,则执行以下操作: 13. `rphead->pktbuf = NULL;`:将 rphead 的 pktbuf 成员变量设置为 NULL,以防止重复存包。 14. `rphead->CdrRaw.ncdrid = node->value_.GetCdrid();`:将 rphead 的 CdrRaw 成员变量中的 ncdrid 设置为 node 的 value_ 成员变量中的 Cdrid。 15. `rphead->CdrRaw.tstart.tm_cycles = node->value_.GetTstart();`:将 rphead 的 CdrRaw 成员变量中的 tstart.tm_cycles 设置为 node 的 value_ 成员变量中的 Tstart。 16. `rphead->CdrRaw.cdrstat = PACKET_END;`:将 rphead 的 CdrRaw 成员变量中的 cdrstat 设置为 PACKET_END。 17. `rphead->btCurStaus = PACKET_END;`:将 rphead 的 btCurStaus 成员变量设置为 PACKET_END。 18. `pubSendPkt((void*)rphead);`:调用 pubSendPkt 函数,将 rphead 作为参数传入。 19. `} else { node->value_.use_count_--; }`:如果 rphead 为空或全局变量 ::is_open_reverse 为假,则将 node 的 value_ 成员变量中的 use_count_ 减 1。 20. `return;`:函数执行完毕,返回。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值