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 相关文章推荐
?牟┛途W扣了一??效果出?? target=
May 27 Javascript
JavaScript 创建对象和构造类实现代码
Jul 30 Javascript
js 代码优化点滴记录
Feb 19 Javascript
jQuery实现的简单折叠菜单(折叠面板)效果代码
Sep 16 Javascript
jQuery旋转插件jqueryrotate用法详解
Oct 13 Javascript
js实现自定义路由
Feb 04 Javascript
JS日程管理插件FullCalendar简单实例
Feb 07 Javascript
Vue.js中轻松解决v-for执行出错的三个方案
Jun 09 Javascript
jQuery常用选择器详解
Jul 17 jQuery
在小程序中集成redux/immutable/thunk第三方库的方法
Aug 12 Javascript
详解Vue.js iview实现树形权限表(可扩展表)
Sep 30 Javascript
Openlayers实现测量功能
Sep 25 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 IP转换整形(ip2long)的详解
2013/06/06 PHP
PHP中使用array函数新建一个数组
2015/11/19 PHP
WordPress后台中实现图片上传功能的实例讲解
2016/01/11 PHP
laravel中的错误与日志用法详解
2016/07/26 PHP
thinkPHP分页功能实例详解
2017/05/05 PHP
使用laravel和ECharts实现折线图效果的例子
2019/10/09 PHP
3Z版基于jquery的图片复选框(asp.net+jquery)
2010/04/12 Javascript
Kibo 用于处理键盘事件的Javascript工具库
2011/10/28 Javascript
Asp.Net alert弹出提示信息的几种方法总结
2014/01/29 Javascript
使用jQuery jqPlot插件绘制柱状图
2014/12/18 Javascript
DOM基础教程之事件对象
2015/01/20 Javascript
seajs学习之模块的依赖加载及模块API的导出
2016/10/20 Javascript
javascript事件的传播基础实例讲解(35)
2017/02/14 Javascript
javascript兼容性(实例讲解)
2017/08/15 Javascript
JS实现的按钮点击颜色切换功能示例
2017/10/19 Javascript
Vue.js与 ASP.NET Core 服务端渲染功能整合
2017/11/16 Javascript
深入浅析var,let,const的异同点
2018/08/07 Javascript
VeeValidate 的使用场景以及配置详解
2019/01/11 Javascript
百度小程序之间的页面通信过程详解
2019/07/18 Javascript
python登录QQ邮箱发信的实现代码
2013/02/10 Python
Python多线程编程(六):可重入锁RLock
2015/04/05 Python
python分数表示方式和写法
2019/06/26 Python
解决django model修改添加字段报错的问题
2019/11/18 Python
Python xlwt模块使用代码实例
2020/06/10 Python
Django web自定义通用权限控制实现方法
2020/11/24 Python
css3 transform 3d 使用css3创建动态3d立方体(html5实践)
2013/01/06 HTML / CSS
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
美国一家全面的在线零售鞋类公司:SHOEBACCA
2017/01/06 全球购物
纽约复古灵感的现代珠宝品牌:Lulu Frost
2018/03/03 全球购物
理货员的岗位职责
2013/11/23 职场文书
营销与策划专业求职信
2014/06/20 职场文书
园林系毕业生求职信
2014/06/23 职场文书
2014国庆黄金周超市促销活动方案
2014/09/21 职场文书
房产转让协议书(2014版)
2014/09/30 职场文书
vue中使用mockjs配置和使用方式
2022/04/06 Vue.js
Python使用PyYAML库读写yaml文件的方法
2022/04/06 Python