我写了一个c nif
代码,当我调用函数find_next
时,erlang vm退出行struct Node *n = (struct Node*) enif_alloc_resource(MEM_RESOURCE, sizeof(Node));
中的分段错误。
C代码:
struct Node {
int n;
int* elems;
int c;
} Node;
static ErlNifResourceType *MEM_RESOURCE;
static ERL_NIF_TERM find_next_nif(ErlNifEnv* env, int argc, const ERL_NIF_TERM argv[])
{
int len;
const ERL_NIF_TERM *args;
if (!enif_get_tuple(env, argv[0], &len, &args))
return enif_make_badarg(env);
struct Node *n = (struct Node*) enif_alloc_resource(MEM_RESOURCE, sizeof(Node));
return enif_make_int(env, 0);
}
有什么问题?
答案 0 :(得分:0)
确保在加载NIF时调用enif_open_resource_type()。
在您的NIF声明中,第三个参数在此示例中为nif_load:
ERL_NIF_INIT(your_nif, nif_funcs, nif_load, NULL, NULL, NULL);
在你的加载函数中,除了你做的任何其他事情,你应该调用enif_open_resource_type(),如下所示:
static int nif_load(ErlNifEnv * env, void ** priv_data, ERL_NIF_TERM load_info) {
...
MEM_RESOURCE = enif_open_resource_type(
env, NULL, "your_nif", NULL,
ERL_NIF_RT_CREATE, NULL);