首页 > 解决方案 > addrinfo 结构在函数调用后不保留值

问题描述

我有一个静态 addrinfo 结构,用于在静态函数 init_socket() 中保存对 getaddressinfo() 的调用结果。在 init_socket() 内部,addrinfo 结构具有正确的值,但在返回时它被归零。

下面是我想要完成的代码。

static struct addrinfo rxRes;

static int init_socket(struct addrinfo *resInfo, char *host, char *port) {
    struct addrinfo hints;
    memset(&hints, 0, sizeof hints);

    hints.ai_family = AF_INET;
    hints.ai_socktype = SOCK_DGRAM;

    if (!host) { // automatically assign ip to result ip of current machine
        hints.ai_flags = AI_PASSIVE;
    }

    int res = getaddrinfo(host, port, &hints, &resInfo);
    if (res != 0 || !resInfo) {
        PRINT_NET_ERR(res);
        exit(EXIT_FAILURE);
    }

    printf("init addrlen: %d\n", resInfo->ai_addrlen); // correct output

    return socket(resInfo->ai_family, resInfo->ai_socktype, resInfo->ai_protocol);
}

int main(int argc, char *argv[])
{
    /* initialize socket connections */
    int rxsFD = init_socket(&rxRes, TEST_HOST, TEST_PORT);
    printf("main addrlen: %d\n, rxRes.ai_addrlen) // outputs 0
    ...
}



标签: csocketsmemory

解决方案


resInfo是函数中的局部变量,因此对它的任何更改都不会反映在调用者中。调用者需要传入一个指向指针的指针,而不仅仅是一个指针。将getaddinfo分配动态内存。是的,这有点令人困惑,所以请查看以下更正的代码,希望它更清晰。

static int init_socket(struct addrinfo **resInfo, char *host, char *port) {
    ..   
    int res = getaddrinfo(host, port, &hints, resInfo);
    ..
}

int main(int argc, char *argv[])
{
    struct addrinfo *rxRes;
    /* initialize socket connections */
    int rxsFD = init_socket(&rxRes, TEST_HOST, TEST_PORT);
    printf("main addrlen: %d\n, rxRes->ai_addrlen);

    /* free the result when no longer needed */
    freeaddrinfo(rxRes);
    ...
}

推荐阅读