1. 下载node.js的源代码。

    https://github.com/joyent/node

    如果用svn下载,后面加上/trunk,以免把用不着的branches也下载下来,浪费时间。

  2. 安装VS, express版本也可以。我安装的是vs2013 ultimate.
  3. 安装python 2.x

    http://www.python.org/download/

    注意不能是3.x, 因为node-gyp目前需要2.x. 我安装的是2.7。

  4. 用命令行工具,Cd到node源代码目录,运行vcbuild.bat。

    成功后,会生成Release或者Debug目录以及其他文件。我的生成是Release目录。我们需要的是这个路径下的node.lib 文件,以便在我们的c++项目中引用。

  5. 打开VS2013,创建一个c++空项目。我的项目起名为myaddon2.

  6. 添加一个main.h和main.cpp文件。这两个文件可以分别放在include和 src 文件夹中,以方便管理。

    在main.cpp引用main.h文件。

    #include
    "main.h"

    由于main.h是放在include文件夹中,需要设置一下才可以。

  7. 设置头文件的引用路径。
    需要添加node源代码路径的src, deps\v8\include, deps\uv\include.

  8. 添加lib所在路径。我们需要这个路径下的node.lib文件。

  9. 在Linker中填入node.lib.

  10. 打开网页:

    https://nodejs.org/api/addons.html#addons_wrapping_c_objects

     

    复制代码并更改,以下是具体文件的代码:

    Main.h 空。

    Main.cpp:

#include
"main.h"

#include
<node.h>

#include
"myobject.h"

 

using
namespace v8;

 

void InitAll(Handle<Object> exports) {

    MyObject::Init(exports);

}

 

NODE_MODULE(myaddon2, InitAll)

Myobject.h

#ifndef MYOBJECT_H

#define
MYOBJECT_H

 

#include
<node.h>

#include
<node_object_wrap.h>

 

class
MyObject : public node::ObjectWrap {

public:

    static
void Init(v8::Handle<v8::Object> exports);

 

private:

    explicit MyObject(double value = 0);

    ~MyObject();

 

    static
void New(const v8::FunctionCallbackInfo<v8::Value>& args);

    static
void PlusOne(const v8::FunctionCallbackInfo<v8::Value>& args);

    static v8::Persistent<v8::Function> constructor;

    double value_;

};

 

#endif

 

Myobject.cpp

#include
"myobject.h"

 

using
namespace v8;

 

Persistent<Function> MyObject::constructor;

 

MyObject::MyObject(double
value) : value_(value) {

}

 

MyObject::~MyObject() {

}

 

void
MyObject::Init(Handle<Object> exports) {

    Isolate* isolate = Isolate::GetCurrent();

 

    // Prepare constructor template

    Local<FunctionTemplate> tpl = FunctionTemplate::New(isolate, New);

    tpl->SetClassName(String::NewFromUtf8(isolate, "MyObject"));

    tpl->InstanceTemplate()->SetInternalFieldCount(1);

 

    // Prototype

    NODE_SET_PROTOTYPE_METHOD(tpl, "plusOne", PlusOne);

 

    constructor.Reset(isolate, tpl->GetFunction());

    exports->Set(String::NewFromUtf8(isolate, "MyObject"),

        tpl->GetFunction());

}

 

void
MyObject::New(const
FunctionCallbackInfo<Value>& args) {

    Isolate* isolate = Isolate::GetCurrent();

    HandleScope scope(isolate);

 

    if (args.IsConstructCall()) {

        // Invoked as constructor: `new MyObject(...)`

        double value = args[0]->IsUndefined() ? 0 : args[0]->NumberValue();

        MyObject* obj = new
MyObject(value);

        obj->Wrap(args.This());

        args.GetReturnValue().Set(args.This());

    }

    else {

        // Invoked as plain function `MyObject(...)`, turn into construct call.

        const
int argc = 1;

        Local<Value> argv[argc] = { args[0] };

        Local<Function> cons = Local<Function>::New(isolate, constructor);

        args.GetReturnValue().Set(cons->NewInstance(argc, argv));

    }

}

 

void
MyObject::PlusOne(const
FunctionCallbackInfo<Value>& args) {

    Isolate* isolate = Isolate::GetCurrent();

    HandleScope scope(isolate);

 

    MyObject* obj = ObjectWrap::Unwrap<MyObject>(args.Holder());

    obj->value_ += 1;

 

    args.GetReturnValue().Set(Number::New(isolate, obj->value_));

}

 

 

  1. 调试。

    设置vs的debug命令和工作路径。

    调试开始后,会自动启动node命令行。

    可以执行以下的命令查看效果。

    如果在 VS 中打上断点,可以进行跟踪。

  2. 使用addon.

    将生成的myaddon2.node文件拷贝到node.js项目文件夹或者子文件夹下。

    var myaddon2 = require("./addons/myaddon2")

    , nodeJsAddOncdObj;

     

     

    app.post('/api/increase/:num', function (req, res){

        if( !myobj ) myobj = new myaddon2.MyObject(req.params.num);

        res.format({

            //HTML returns us back to the main page, or you can create a success page

             html: function(){

                 //only return json.

             },

             //JSON returns the item with the message that is has been deleted

            json: function(){

                 res.json({

                     success:true,

                     result : myobj.plusOne()

                 });

             }

         });

     

    });

     

     

用vs2013开发node.js的addon.的更多相关文章

  1. 在开发node.js中,关于使用VS2013插件出现一直读取资源的问题

    情况描述: 1.安装了VS2013: 2.安装了VS开发node.js的插件; 3.打开以前的工程文件,有的可以打开,有的打不开.而且打不开的始终停留在读取资源的界面.很痛苦的.等半天都没有反应.到底 ...

  2. 【转】使用VS开发 Node.js指南

    参考:https://www.visualstudio.com/features/node-js-vs 这篇文章主要介绍了使用VS开发 Node.js的方法,主要是使用NTVS(Node.js Too ...

  3. VS2013创建Node.js C++ Addons的过程

    首先看我的Node.js版本. node –v v6.11.4 然后参照这篇文章来做: https://nodejs.org/api/addons.html#addons_hello_world 安装 ...

  4. VS轻松开发Node.js应用

    PTVS开发团队又开发出一款可以在VS里编写Node.js应用程序的插件--NTVS(Node.js Tools for Visual Studio),开发者可以在VS里轻松开发Node.js应用. ...

  5. 在Visual Studio上开发Node.js程序(2)——远程调试及发布到Azure

    [题外话] 上次介绍了VS上开发Node.js的插件Node.js Tools for Visual Studio(NTVS),其提供了非常方便的开发和调试功能,当然很多情况下由于平台限制等原因需要在 ...

  6. 在Visual Studio上开发Node.js程序

    [题外话] 最近准备用Node.js做些东西,于是找找看能否有Visual Studio上的插件以方便开发.结果还真找到了一个,来自微软的Node.js Tools for Visual Studio ...

  7. 在Visual Studio 2013 上开发Node.js程序

    [题外话] 最近准备用Node.js做些东西,于是找找看能否有Visual Studio上的插件以方便开发.结果还真找到了一个,来自微软的Node.js Tools for Visual Studio ...

  8. 在Sublime Text3 开发Node.js遇到的一个小问题

    原文摘自我的前端博客,欢迎大家来访问 http://www.hacke2.cn 以前的Sublime Text 2包管理出现问题了,不能安装新包,让人开发很捉急,今天装了个3,这个问题解决了 那我们就 ...

  9. KoaHub.js:使用ES6/7特性开发Node.js框架

    KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架.可以直接在项目里使用 ES6/7(Generator Function, Class, Async & ...

随机推荐

  1. event使用说明和DHTML参数属性

    event 对象 代表事件状态,如事件发生的元素,键盘状态,鼠标位置和鼠标按钮状态. DHTML元素属性列表 属性 描述 abstract 使用 event 对象获取高级流重定向器(ASX)文件中项目 ...

  2. 【BZOJ 3661】 Hungry Rabbit (贪心、优先队列)

    3661: Hungry Rabbit Time Limit: 100 Sec  Memory Limit: 512 MBSec  Special JudgeSubmit: 67  Solved: 4 ...

  3. java线程本地变量

      ThreadLocal是什么呢?其实ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是threadlocalvariable(线程局部变量).也许把它命名为Thre ...

  4. bzoj hash+map+set

    先对原串分组hash,查询就是看某一区间内是否出现某值. 可以每个值存一个集合,保存这个值出现的位置.(也可以建可持久化值域线段树) map<int,set<int> >很省事 ...

  5. cdoj 841 休生伤杜景死惊开 逆序数/树状数组

    休生伤杜景死惊开 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) 陆伯言军陷八卦 ...

  6. 记一次完整的pc前端整站开发

    我所做的项目是一个线上的旅游平台,当然不是大家耳熟能详的那些旅游平台了,项目刚开始也没有必要去评价它的好坏,在这里我就不多说了~这是线上地址有兴趣的同学可以去看看(www.bookingctrip.c ...

  7. angularjs鼠标移入移出实现显示隐藏

    <tr ng-repeat="item in items track by $index"> <td data-title="操作" alig ...

  8. 74HC125 74HCT125 74LV125 74LVC125

    74HC125; 74HCT125Quad buffer/line driver; 3-state The 74HC125; 74HCT125 is a quad buffer/line driver ...

  9. firedac引擎DATASNAP多表查询和多表提交

    firedac引擎DATASNAP多表查询和多表提交 属性设置FDTableAdapter1.SchemaAdapter := FDSchemaAdapter;FDTableAdapter1.DatS ...

  10. 值得借鉴的Objective-C编程规范

    Daniel's Objective-C Coding Style Guidelines http://google-styleguide.googlecode.com/svn/trunk/objcg ...