C中嵌套结构的指针类型

时间:2019-05-03 10:12:23

标签: c

是否可以在C语言中创建指向嵌套结构的内部结构的指针?

#include <stdio.h>
#include <stdint.h>

typedef struct
{
    uint8_t first;
    struct
    {
        uint8_t second;
        uint8_t third[8];
    } inner_struct;
} outer_struct;

int main()
{
    outer_struct foo;
    void * p = &foo.inner_struct;
    printf("%d", sizeof(p->third));
    return 0;
}

使用空指针我可以指向它,但出现此错误

main.c: In function 'main':
main.c:26:26: error: request for member 'third' in something not a structure or union
     printf("%d", sizeof(p->third));
                          ^~

当尝试获取“第三”数组的大小时。我也可以使用指向external_struct的指针,但真正的示例是事件更嵌套,并且包含长变量名,这使得它很难阅读。是否可以直接创建指向内部结构的指针?

使用 struct inner_struct * p = &foo.inner_struct;而不是无效收益

main.c: In function 'main':
main.c:25:31: warning: initialization from incompatible pointer type [-Wincompatible-pointer-types]
     struct inner_struct * p = &foo.inner_struct;
                               ^
main.c:26:26: error: dereferencing pointer to incomplete type 'struct inner_struct'
     printf("%d", sizeof(p->inner_struct.third));
                          ^~

1 个答案:

答案 0 :(得分:3)

类型void *是可以指向任何内容的通用指针。但是编译器实际上并不知道它指向的内容,因此您必须使用强制转换来告知它。

因此,要使p->third工作,您需要将指针p转换为正确的指针类型。

不幸的是,这对于您当前的代码是不可能的,因为内部结构是没有已知 tag (结构名)的匿名结构。您需要创建一个可用于铸造的结构标签。例如

typedef struct
{
    uint8_t first;
    struct inner_struct
    {
        uint8_t second;
        uint8_t third[8];
    } inner_struct;
} outer_struct;

现在,您可以像p一样投射指针((struct inner_struct *) p)->third

或立即将p定义为正确的类型:

struct inner_struct *p = &foo.inner_struct;