node.js调用C++函数的方法示例


Posted in Javascript onSeptember 21, 2018

目前nodejs调用c++主流的有两种方法,分别是addons和ffi

addons是nodejs官方的c++扩展实现方案,但是由于需要使用模版,并且要对v8引擎有一定的了解,入门门槛较高。

ffi是nodejs直接调用so库的一种实现,可以调用纯c的接口。

要想node.js调用C++的函数等,须先将C++代码编译成二进制的.node文件。node.js官方文档https://nodejs.org/dist/latest-v8.x/docs/api/addons.html中的C++ addons介绍了如何将C++的代码编译为二进制的.node文件。

一、步骤:

1.首先在项目目录进行npm install -g node-gyp下载node-gyp模块,配置环境参考https://github.com/nodejs/node-gyp

2.这是node官方文档中的例子

// addon.cc
#include <node.h>
namespace demo {
using v8::Exception;
using v8::FunctionCallbackInfo;
using v8::Isolate;
using v8::Local;
using v8::Number;
using v8::Object;
using v8::String;
using v8::Value;// This is the implementation of the "add" method// Input arguments are passed using the// const FunctionCallbackInfo<Value>& args struct
void Add(const FunctionCallbackInfo<Value>& args) {
 Isolate* isolate = args.GetIsolate();
 // Check the number of arguments passed.
 if (args.Length() < 2) {
 // Throw an Error that is passed back to JavaScript
 isolate->ThrowException(Exception::TypeError(
  String::NewFromUtf8(isolate, "Wrong number of arguments")));
 return;
 }
 // Check the argument types
 if (!args[0]->IsNumber() || !args[1]->IsNumber()) {
 isolate->ThrowException(Exception::TypeError(
  String::NewFromUtf8(isolate, "Wrong arguments")));
 return;
 }
 // Perform the operation
 double value = args[0]->NumberValue() + args[1]->NumberValue();
 Local<Number> num = Number::New(isolate, value);
 // Set the return value (using the passed in
 // FunctionCallbackInfo<Value>&)
 args.GetReturnValue().Set(num);}
void Init(Local<Object> exports) {
 NODE_SET_METHOD(exports, "add", Add);}NODE_MODULE(NODE_GYP_MODULE_NAME, Init)
} // namespace demo

3.然后在项目目录下使用类似JSON的格式创建在项目顶层调用的文件binding.gyp文件,内容为

{
 "targets": [
 {
  "target_name": "addon",
  "sources": [ "addon.cc" ]
 }
 ]
}

4.在终端输入node-gyp configure命令生成一个build文件夹,然后输入node-gyp build命令生成编译addon.node文件

5.在node文件比如test.js文件中const addon=require(‘./build/Release/addon')调用生成的模块

// test.js
const addon = require('./build/Release/addon');
console.log('This should be eight:', addon.add(3, 5));//结果为8

二、实例

最近公司让我研究node调用C++,C++的代码是调用了GDAL库开发的功能。要在tile.cc文件中调用头文件

node.js调用C++函数的方法示例

这里#include调用的gdal_priv.h和ogrsf_frmts.h头文件在gdal/include文件夹中,所以要在binding.gyp文件中source后面添加

"include_dirs": [
  "./gdal/include"
  ],

然后如果现在就运行node-gyp configure build命令会报“无法解析的外部符号”的错误,这是因为还需要加入调用的链接库,需要在binding.gyp文件中加入

'libraries': [
   "../gdal/lib/gdal_i.lib",
  ],

这时的binding.gyp文件为

{
 "targets": [
 {
  "target_name": "addon",
  "sources": [
  "./C++_02/tile.cc"
  ],
  "include_dirs": [
  "./gdal/include"
  ],
  'libraries': [
   "../gdal/lib/gdal_i.lib",
  ],
 }
 ]
}

这时再进行node-gyp configure build命令就不会报错生成addon.node文件,但是当我运行test.js文件

const addon=require(‘./build/Release/addon')
var imagefile = "/vsicurl/http://sasmac.oss-cn-beijing.aliyuncs.com/cog.tif";
var x = 160;
var y = 83;
var l = 9;
console.log(addon.tileload(imagefile, x, y, l));

会报错'找不到指定的模块',但是我们在build/Release文件中能找到addon.node文件,这是因为缺少依赖也就是缺少.dll。下载 Dependency Walker,这个软件可以帮你确定一下缺少什么.dll,下载地址:http://www.dependencywalker.com/。我将addon.node文件添加到Dependency Walker发现缺少gdal/bin中的.dll。我将gdal/bin中的.dll文件复制到addon.node目录下,这时运行test.js文件就可以正常使用了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 表单验证方法(实用)
Apr 28 Javascript
js 数组操作之pop,push,unshift,splice,shift
Jan 29 Javascript
浅析jQuery事件之on()方法绑定多个选择器,多个事件
Apr 27 Javascript
探讨:JavaScript ECAMScript5 新特性之get/set访问器
May 05 Javascript
jQuery中fadein与fadeout方法用法示例
Sep 16 Javascript
js实现三级联动效果(简单易懂)
Mar 27 Javascript
.net MVC+Bootstrap下使用localResizeIMG上传图片
Apr 21 Javascript
AngularJS与BootStrap模仿百度分页的示例代码
May 23 Javascript
vue 弹框产生的滚动穿透问题的解决
Sep 21 Javascript
nodemon实现Typescript项目热更新的示例代码
Nov 19 Javascript
基于PHP pthreads实现多线程代码实例
Jun 24 Javascript
vue3.0搭配.net core实现文件上传组件
Oct 29 Javascript
Vue中Quill富文本编辑器的使用教程
Sep 21 #Javascript
vue单页应用在页面刷新时保留状态数据的方法
Sep 21 #Javascript
vue如何安装使用Quill富文本编辑器
Sep 21 #Javascript
vue中设置、获取、删除cookie的方法
Sep 21 #Javascript
Vue实现动态添加或者删除对象和对象数组的操作方法
Sep 21 #Javascript
vue富文本编辑器组件vue-quill-edit使用教程
Sep 21 #Javascript
React实现全局组件的Toast轻提示效果
Sep 21 #Javascript
You might like
php数组函数序列之array_search()- 按元素值返回键名
2011/11/04 PHP
深入PHP与浏览器缓存的分析
2013/06/03 PHP
php生成随机数/生成随机字符串的方法小结【5种方法】
2020/05/27 PHP
多个iframe自动调整大小的问题
2006/09/18 Javascript
JavaScript获取GridView中用户点击控件的行号,列号
2009/04/14 Javascript
javascript中的window.location.search方法简介
2013/09/02 Javascript
javascript实现日期时间动态显示示例代码
2015/09/08 Javascript
JS+CSS实现精美的二级导航效果代码
2015/09/17 Javascript
chrome调试javascript详解
2015/10/21 Javascript
js以分隔符分隔数组中的元素并转换为字符串的方法
2016/11/16 Javascript
JavaScript Ajax实现异步通信
2016/12/14 Javascript
js获取文件里面的所有文件名(实例)
2017/10/17 Javascript
基于js实现抽红包并分配代码实例
2019/09/19 Javascript
jQuery实现手风琴特效
2021/01/11 jQuery
Python自定义函数的创建、调用和函数的参数详解
2014/03/11 Python
跟老齐学Python之关于类的初步认识
2014/10/11 Python
python获取指定目录下所有文件名列表的方法
2015/05/20 Python
详解用TensorFlow实现逻辑回归算法
2018/05/02 Python
基于Django静态资源部署404的解决方法
2019/07/28 Python
python基于celery实现异步任务周期任务定时任务
2019/12/30 Python
PyTorch 普通卷积和空洞卷积实例
2020/01/07 Python
浅谈keras中的Merge层(实现层的相加、相减、相乘实例)
2020/05/23 Python
Django Admin后台模型列表页面如何添加自定义操作按钮
2020/11/11 Python
CSS3盒子模型详解
2013/04/24 HTML / CSS
为什么会有内存对齐
2016/10/10 面试题
初中女生自我鉴定
2013/12/19 职场文书
心理健康教育心得体会
2013/12/29 职场文书
幼儿园清明节活动总结
2014/07/04 职场文书
商家认证委托书格式
2014/10/16 职场文书
2015年服务员工作总结
2015/04/08 职场文书
2015年教研员工作总结
2015/05/26 职场文书
2015年校本培训工作总结
2015/07/24 职场文书
信息技术课教学反思
2016/02/23 职场文书
2019各种保证书范文
2019/06/24 职场文书
Python实现照片卡通化
2021/12/06 Python
MongoDB数据库之添删改查
2022/04/26 MongoDB