我想将C调用从C示例移植到C ++示例。但是我不确定什么是正确的方法。在内存集部分,我应该用C ++代码代替什么?
static int begin_request_handler(struct mg_connection *conn) {
return 1;
}
struct mg_callbacks {
int (*begin_request)(struct mg_connection *);
void (*end_request)(const struct mg_connection *, int reply_status_code);
int (*log_message)(const struct mg_connection *, const char *message);
int (*init_ssl)(void *ssl_context);
int (*websocket_connect)(const struct mg_connection *);
void (*websocket_ready)(struct mg_connection *);
int (*websocket_data)(struct mg_connection *);
const char * (*open_file)(const struct mg_connection *,
const char *path, size_t *data_len);
void (*init_lua)(struct mg_connection *, void *lua_context);
void (*upload)(struct mg_connection *, const char *file_name);
};
struct mg_callbacks callbacks;
memset(&callbacks, 0, sizeof(callbacks));
callbacks.begin_request = begin_request_handler;
如果我从C ++调用memset,它的外观应该如何?
好,所以我会这样:
struct mg_callbacks callbacks = { };
将用零值填充它。
但是memset
很好-C ++旨在采用C代码,而几乎不需要修改,因此,如果您不需要更改某些内容,那么我看不出更改代码的真正原因。
您当然也可以在mg_callbacks
中声明一个构造函数,该构造函数将每个指针设置为NULL
,例如
struct mg_callbacks
{
mg_callbacks()
{
begin_request = NULL;
...
}
...
};
这将保证没有代码会忘记“内存集”。
当然,整个结构似乎应该是带有虚拟函数的基类,然后为实现派生类中的不同目的而专门实现这些虚函数。但这与使用memset
无关。
如果需要,可以在C ++中使用memset,但是如果您习惯于使用惯用的C ++方法设置内存块,那么您想要的就是std :: fill。