使用c++为node.js扩展模块

官方文档

编写c++代码

// demo.cc
#include <node.h>

using v8::FunctionCallbackInfo;
using v8::Isolate;
using v8::Local;
using v8::Object;
using v8::Value;
using v8::Number;

double Sum(){
  int i;
  double a = 3.1415926,b = 2.718;
  for(i = 0;i<1000000000;i++){
    a+=b;
  }
  return a;
}

void Method(const FunctionCallbackInfo<Value>& args) {
  Isolate* isolate = args.GetIsolate();
  double a = Sum();
  auto total = Number::New(isolate , a);
  args.GetReturnValue().Set(total);
}

void init(Local<Object> exports) {
  NODE_SET_METHOD(exports, "sum", Method);
}

NODE_MODULE(addon, init)

编写配置文件

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

编译

node-gyp configure build##

js引入执行

let addon = require('./build/Release/addon')
function Sum(){
    let a = 3.1415926
    let b = 2.718;
    for(let i = 0;i<1000000000;i++){
        a+=b;
    }
    return a;
}
console.time("C++")
console.log(addon.sum())
console.timeEnd("C++")
console.time('JS')
console.log(Sum())
console.timeEnd('JS')

分析

以上代码是将a循环加上b,循环十亿次

看一下输出结果不同机器结果可能不同,但整体差距大致相同
1062600-20170806141809147-822460458.png

此处c++耗时972.209ms 1s = 1000ms
js耗时13637.128ms

转载于:https://www.cnblogs.com/zheng-chuang/p/7294653.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值