Nodejs Addons uv_queue_work分段错误

时间:2015-04-26 16:46:38

标签: c++ node.js libuv

我正在尝试创建一个非常小的nodejs插件示例。 我的c ++代码是这样的:

void __sleep(uv_work_t* req) {
    usleep(1000 * 1000 * 5); // = 5seconds
}

void after(uv_work_t *handle, int status) {
    printf("After\n");
}

Handle<Value> foo(const Arguments& args) {
    HandleScope scope;
    uv_loop_t *loop = uv_default_loop();
    uv_work_t req;
    uv_queue_work(loop, &req, __sleep, after);
    return scope.Close(Undefined());
}

void InitAll(Handle<Object> exports, Handle<Object> module) {
    NODE_SET_METHOD(exports, "foo", foo);
}

NODE_MODULE("myModule", InitAll)

在js中,这个:

console.log(myModule);
myModule.foo();
console.log("started sleeping...");

当我调用myModule.foo函数时,该过程以分段错误终止。

我尝试添加uv_run(loop, UV_RUN_DEFAULT),但这会阻止主线程。

我哪里出错了? 感谢

1 个答案:

答案 0 :(得分:4)

问题是req在堆栈上分配,并在foo返回时释放。您需要在堆上分配它(使用newmalloc)并在完成后手动释放它(例如,在after回调中)