用C++編寫擴(kuò)展node.js(node-ffi版)
用C++擴(kuò)展node.js(node-ffi版)
0.先安裝node.js和python(2.7)。請參考:
https://nodejs.org/
https://www.python.org
1.新建一個demo項(xiàng)目: 創(chuàng)建demo目錄,并進(jìn)入其中,然后運(yùn)行下面命令。
mkdir demo cd demo npm init
運(yùn)行npm init時,之后會生成一個package.json(具體內(nèi)容與輸入?yún)?shù)有關(guān)):
{ "name": "demo", "version": "1.0.0", "description": "a demo for node call native functions", "main": "demo.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "keywords": [ "node" ], "author": "Li XianJing", "license": "ISC" }
2.安裝編譯工具和頭文件。
sudo npm install -g node-gyp npm install ffi bindings --save
3.用C++編寫原生代碼( 為了讓目錄結(jié)構(gòu)整潔一點(diǎn),我們把代碼放到native只目錄下)。
下面的文件(native/demo.cc),添加一個Add方法,計(jì)算兩個數(shù)之和:
double Add(double a, double b) { return a+b; }
4.寫一個Makefile(native/Makefile), 用來編譯C++代碼。
all: $(CC) -g -shared demo.c -o libdemo.dylib clean: rm -frv libdemo*
5.編寫一個JS文件(demo.js)),讓它調(diào)用原生代碼。
var ffi = require('ffi'); var demo = ffi.Library('./native/libdemo', { 'Add': [ 'double', [ 'double', 'double'] ] }); console.log(demo.Add(12345, 54321));
7.編譯C++程序。
make -C native
8.運(yùn)行JS代碼,看看是否工作。
node demo.js
參考:
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
C++靜態(tài)成員變量和靜態(tài)成員函數(shù)的使用方法總結(jié)
下面小編就為大家?guī)硪黄狢++靜態(tài)成員變量和靜態(tài)成員函數(shù)的使用方法總結(jié)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01Microsoft Visual C++ 6.0開發(fā)環(huán)境搭建教程
這篇文章主要為大家詳細(xì)介紹了Microsoft Visual C++ 6.0開發(fā)環(huán)境搭建教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04C/C++函數(shù)參數(shù)聲明解析int?fun()?與?int?fun(void)?的區(qū)別講解
C++中int fun()和int fun(void)的區(qū)別在于函數(shù)參數(shù)的聲明方式,前者默認(rèn)允許任意參數(shù),而后者表示沒有參數(shù),通過清晰的實(shí)例源代碼,詳細(xì)解釋了它們在函數(shù)聲明和調(diào)用中的不同之處,這篇文章介紹了C/C++函數(shù)參數(shù)聲明int?fun()與int?fun(void)的差異,需要的朋友可以參考下2024-01-01