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. Spring的模块组成

    Spring的模块组成 1.核心容器:核心容器提供 Spring 框架的基本功能(Spring Core).核心容器的主要组件是 BeanFactory,它是工厂模式的实现. BeanFactory ...

  2. 【堆优化Dijkstra+字典序最短路方案】HDU1385-Minimum Transport Cost

    [题目大意] 给出邻接矩阵以及到达各个点需要付出的代价(起点和终点没有代价),求出从给定起点到终点的最短路,并输出字典序最小的方案. [思路] 在堆优化Dijkstra中,用pre记录前驱.如果新方案 ...

  3. 热爱编程,热爱生活,快速适应IT新技术

    现在新技术层出不穷,我们没有那么多时间去深入学习每一门.对于大多数技术,我们只需要搞懂概念部分,从宏观上了解一下,决定我们要不要深入地去学习它.有了这些了解,就能轻松地与别人聊天了,也可以为以后技术选 ...

  4. Python环境右键定制

    有时候,我们需要将py打包成exe.需要将ui转换成py.需要将py转换成pyc等等,命令行操作起来有点繁琐.所以做了这个教程: 1. py打包成exe 先安装cx_freeze,参照教程:http: ...

  5. Codeforces Round #356 (Div. 2) A. Bear and Five Cards 水题

    A. Bear and Five Cards 题目连接: http://www.codeforces.com/contest/680/problem/A Description A little be ...

  6. wikioi 1080 线段树练习 树状数组

    1080 线段树练习 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond       题目描述 Description 一行N个方格,开始每个格子里都有一个整数.现 ...

  7. 解决CIFilter滤镜后图片大小和方向发生变化

    调用contextWithOptions:和createCGImage: fromRect:方法创建CIContext.与以往不同的地方是CIImage没有frame与bounds属性:只有exten ...

  8. 客户端程序获取自己的ip、isp、地理位置等信息

    @ 比如说你需要收集用户信息,又或者要通过这些信息让用户登陆合适的服务器(北京联通用户登陆北京联通服务器). @ 淘宝和新浪都提供了类似的API,你只需要发送一个http请求,它就返回一个json格式 ...

  9. USB Mass Storage Class – Bulk Only Transport - Error Handling

    6.4 Device Error Handling The device may not be able to fully satisfy the host's request. At the poi ...

  10. Maven私仓配置

    <?xml version="1.0" encoding="UTF-8"?> <settings xmlns="http://mav ...