将内存集从C替换/移植到C ++

问题描述 投票:0回答:2

我想将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,它的外观应该如何?

c++ port porting memset
2个回答
3
投票

好,所以我会这样:

struct mg_callbacks callbacks = { }; 

将用零值填充它。

但是memset很好-C ++旨在采用C代码,而几乎不需要修改,因此,如果您不需要更改某些内容,那么我看不出更改代码的真正原因。

您当然也可以在mg_callbacks中声明一个构造函数,该构造函数将每个指针设置为NULL,例如

struct mg_callbacks 
{
   mg_callbacks()
   {
      begin_request = NULL;
      ...
   }
   ... 
};

这将保证没有代码会忘记“内存集”。

当然,整个结构似乎应该是带有虚拟函数的基类,然后为实现派生类中的不同目的而专门实现这些虚函数。但这与使用memset无关。


0
投票

如果需要,可以在C ++中使用memset,但是如果您习惯于使用惯用的C ++方法设置内存块,那么您想要的就是std :: fill。

© www.soinside.com 2019 - 2024. All rights reserved.