Node.js調(diào)用C++實(shí)踐

? 閑話不瞎扯,直奔主題,本人環(huán)境ubuntu18.04

環(huán)境配置

  1. 你得有node環(huán)境,此處默認(rèn)已有

  2. 編譯工具"node-gyp"安裝:

    npm install node-gyp -g  
    

    具體安裝時(shí)可能會需要一些其他依賴,詳見其 github主頁,一般直接敲命令即可

邊緣試探

? 先來個(gè)"hello world"開胃菜體驗(yàn)下js調(diào)用c++和c++回調(diào),文件主要包括3部分:

文件

  • 配置文件

    在項(xiàng)目根目錄下創(chuàng)建binding.gyp配置文件,內(nèi)容格式如下:

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

    此處是極簡配置哦

  • cc文件

    #include <node.h>
    #include <v8.h>
    
    using namespace v8;
    
    // 參數(shù)是從js端傳進(jìn)來的
    void hello(const FunctionCallbackInfo<Value> &args)
    {
      // 使用 HandleScope 來管理生命周期
      Isolate *isolate = Isolate::GetCurrent();
      HandleScope scope(isolate);
    
      // 判斷參數(shù)長度和格式,不符合就拋出異常
      if (args.Length() < 2 || !args[0]->IsString())
      {
        isolate->ThrowException(Exception::TypeError(
            String::NewFromUtf8(isolate, "Wrong arguments")));
        return;
      }
    
      // callback, 使用Cast方法來轉(zhuǎn)換
      Local<Function> callback = Local<Function>::Cast(args[1]);
      // 返回給js端的結(jié)果數(shù)組
      Local<Value> argv[1] = {
          String::Concat(Local<String>::Cast(args[0]), String::NewFromUtf8(isolate, " world"))};
      // 調(diào)用js端傳進(jìn)來的回調(diào)函數(shù),參數(shù): 當(dāng)前上下文,參數(shù)個(gè)數(shù),結(jié)果數(shù)組
      callback->Call(isolate->GetCurrentContext()->Global(), 1, argv);
    }
    
    // 相當(dāng)于在 exports 對象中添加 { hello: hello }
    void init(Handle<Object> exports)
    {
      NODE_SET_METHOD(exports, "hello", hello);
    }
    
    // 將 export 對象暴露出去
    // 原型 `NODE_MODULE(module_name, Initialize)`
    NODE_MODULE(test, init);
    
  • js文件

    js文件首先加載c++的模塊,然后調(diào)用,如下:

    var test = require('./build/Release/test');
    test.hello('hello', function(data) {
      console.log(data);
    });
    

編譯和運(yùn)行

node-gyp configure
node-gyp build
node test.js

? 好了,此時(shí)應(yīng)該可以看到控制臺輸出"hello world"了。但是,一般我們都是手頭上有一個(gè)現(xiàn)成的庫需要去調(diào)用,可不是寫個(gè).cc源文件輸出"hello world"可以完事的,咱看下一步。代碼見 github

入門一

? 此處以調(diào)用bsdiff算法為例(本人用來做apk的增量更新),生成差分包,目錄結(jié)構(gòu)如下:

  • bsdiff

    存放bsdiff源碼目錄

  • bzip2

    bsdiff需要用到的依賴

  • folder

    放差分的示例文件

  • binding.gyp

    node-gyp編譯配置文件

  • bsdiff.cc

    native原生入口文件

  • bsdiff.js

功能:

  • [x] 生成差分包
  • [ ] 合并差分包

內(nèi)容比較簡單,主要比一章的多個(gè)調(diào)用外部庫,主要展示調(diào)用方式,詳見源碼 github 。

此算法的封裝有現(xiàn)成的npm庫,見:bsdiff-node ,這里就不做深入封裝了。

參考

  1. 官方例子

本文由Owen Lee原創(chuàng),轉(zhuǎn)載請注明來源:
http://www.itdecent.cn/p/bec945651fb1

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容