分配指向结构数组的指针

Posted

技术标签:

【中文标题】分配指向结构数组的指针【英文标题】:Mallocing pointer to array of structs 【发布时间】:2021-12-14 03:51:07 【问题描述】:

我正在尝试使用一些自定义库来制作 HTTP 响应。库函数需要一个指向自定义结构HttpHeader 的数组的指针。代码下方是手册页中的 sn-p。我想知道如何初始化它,以便Content-Length 填充名称和一个值填充值,然后数组中的下一个HttpHeader 是手册页指定的NULL 指针。以下是我目前拥有的代码,但我的系统在为标头分配原始内存时出错:

错误:“HttpHeader”之前的预期表达式 HttpHeader** headers = malloc(sizeof(**HttpHeader));

如何解决这个错误?

我的代码:

 void populate_header(HttpHeader** headers, char* value) 
        headers[0]->name = malloc(sizeof(char) * strlen("Content-Length"));
        headers[0]->value = malloc(sizeof(char) * strlen(value));
        strcpy(headers[0]->name, "Content-Length");
        strcpy(headers[0]->value, value);
    

char* process_address(char** addrContents) 
    HttpHeader** headers = malloc(sizeof(*HttpHeader));
    char* body = NULL;
    char* response = NULL;
    if (strcmp(addrContents[1], "validate") == 0) 
        populate_header(headers, "0");
        if (!check_expression(addrContents[2])) 
            response = construct_HTTP_response(400, "Bad Request", headers, body);
         else 
            response = construct_HTTP_response(200, "OK", headers, body);
        
     else if (strcmp(addrContents[1], "integrate") == 0) 
        if (!check_expression(addrContents[2])) 
            populate_header(headers, "0");
            response = construct_HTTP_response(400, "Bad Request", headers, body);
         else 

            response = construct_HTTP_response(200, "OK", headers, body);
        
     else 
        populate_header(headers, "0");
        response = construct_HTTP_response(400, "Bad Request", headers, body);
    
    //printf("Response: %s\n", response);
    return response;

手册页:

headers
              points to an array of HttpHeader* (see below), each containing the name of value of a HTTP header. The last entry in headers will be a NULL
              pointer.

   HttpHeader
       A HttpHeader is defined as follows:
       typedef struct 
           char* name;
           char* value;
        HttpHeader;
       Memory for name and value is allocated separately.

【问题讨论】:

正确答案取决于construct_HTTP_response 是否拥有headers 指向的任何东西。 您没有在populate_header 中分配足够的空间。因为 C 字符串以空字节结尾,所以需要分配 strlen + 1。更好的是,使用 strdup 【参考方案1】:

sizeof(*HttpHeader) 是问题所在。 * 取消引用一个指针。 HttpHeader 是一个类型,取消引用一个类型是没有意义的。

你想要sizeof(HttpHeader*)。这就是指向HttpHeader 的指针类型。

malloc(sizeof(HttpHeader*)); 只为单个指针分配空间。如果要为多个标头分配空间,则需要相乘。例如,如果您想要五个标题的空间:malloc(sizeof(HttpHeader*) * 5);

最后,数组应该以 null 结束,这样它就知道何时停止读取数组。分配比您需要的多一个指针,并将最后一个元素设置为 null。

// Space for two headers, the last is a null.
HttpHeader** headers = malloc(sizeof(*HttpHeader) * 2);
headers[1] = NULL;

类似地,C 中的字符串以 null 结尾。你必须比字符串的长度多分配一个字节。

sizeof(char) 定义为 1,可以省略。

void populate_header(HttpHeader** headers, char* value) 
  headers[0]->name = malloc(strlen("Content-Length") + 1);
  headers[0]->value = malloc(strlen(value) + 1);
  strcpy(headers[0]->name, "Content-Length");
  strcpy(headers[0]->value, value);

更好的是,使用strdup

void populate_header(HttpHeader** headers, char* value) 
  headers[0]->name = strdup("Content-Length");
  headers[0]->value = strdup(value);

【讨论】:

以上是关于分配指向结构数组的指针的主要内容,如果未能解决你的问题,请参考以下文章

在 C 中声明指向结构的指针数组,但在需要之前不为结构分配内存

动态分配的指向结构(链表)的指针数组,以及如何访问每个列表?

在C中为结构指针数组成员分配地址

返回指向结构数组的指针

使用指向结构数组的指针不会返回完整的数组

C++结构体指针数组如何分配空间,用new