-2

我不知道为什么这段代码会出现这个错误。我应该怎么办?错误如下:

灵活数组成员的使用无效

在这条线上:

new_buffer->array_msg =array;

如果是更大的代码部分:

   typedef struct buffer {
    int size;
    int T;
    int D;
    int msg_presenti;

    pthread_cond_t not_full;
    pthread_cond_t not_empty;
    pthread_mutex_t mutex;
    msg_t * array_msg[];

} buffer_t;

buffer_t * buffer_init(unsigned int maxsize){
    buffer_t * new_buffer = malloc( sizeof(buffer_t) + maxsize * sizeof(msg_t) );

    msg_t * array[maxsize];
    new_buffer->array_msg =array;
    new_buffer->size=maxsize;
    return new_buffer;
}
// deallocazione di un buffer
4

1 回答 1

2

此行足以为您的结构和灵活数组成员分配空间:

buffer_t * new_buffer = malloc( sizeof(buffer_t) + maxsize * sizeof(msg_t *) );
                                ^                  ^
                                1                  2

1将为结构分配内存,同时为灵活的数组成员2分配空间,因此您的函数应如下所示:

buffer_t * buffer_init(unsigned int maxsize)
{
    buffer_t * new_buffer = malloc( sizeof(buffer_t) + maxsize * sizeof(msg_t) );

    new_buffer->size=maxsize;
    return new_buffer;
}

如果我们查看草案 C99 标准部分6.7.2.1结构和联合说明符第17段给出以下示例:

示例声明后:

struct s { int n; double d[]; };

结构 structs具有灵活的数组成员d。一个典型的使用方法是:

int m = /* some value */;
struct s *p = malloc(sizeof (struct s) + sizeof (double [m]));

并假设调用malloc成功,在大多数情况下,指向的对象的p行为就像p被声明为:

struct { int n; double d[m]; } *p;

(在某些情况下,这种等价性会被破坏;特别是,成员的偏移量d可能不一样)。

于 2013-11-27T16:35:39.837 回答