结构中的指针放置在两个结构成员上

时间:2019-11-24 13:52:07

标签: c arrays pointers struct

我试图用C实现一个环形缓冲区。我声明了一个带有某些参数的struct ring_buffer,一个指向ring_buffer元素的指针数组以及一个释放缓冲区元素的回调函数(指针)。

struct ring_buffer
{
    size_t size, count, head;
    void **elems;
    void (*free_callback)(void *p);
};
typedef struct ring_buffer ring_buffer;

除此之外,我还有一个初始化函数来创建该结构的新实例。

ring_buffer *init_buffer(const size_t n, void (*f)(void *p))
{
    ring_buffer *buffer = NULL;
    size_t count = 0, head = 0;
    void **elems = NULL;

    if(n <= 0 || f == NULL)
    {
        return NULL;
    }

    buffer = malloc(sizeof(buffer));
    elems = (void**)malloc(n * sizeof(void*));

    *buffer = (ring_buffer){.size = n, .count = count, .head = head, .elems = elems, .free_callback = f};

    return buffer;
}

现在我遇到以下问题: 调用init_buffer函数并创建新结构后,回调函数的指针也将放置在该结构的free_callback成员以及elems数组的第一个索引上!意思是 free_callback == elems[0]

我为整个数组和结构分配足够的空间感到困惑,所以为什么free_callback指针与数组的第一个索引重叠。

感谢您的帮助!

1 个答案:

答案 0 :(得分:3)

buffer = malloc(sizeof(buffer));

您以指针的大小分配存储空间,而不是环形缓冲区。 请重写:

buffer = malloc(sizeof(ring_buffer))