C:sizeof单个结构成员
我试图声明一个依赖于另一个结构的结构。 我想用sizeof
来安全/迂腐。
typedef struct _parent { float calc ; char text[255] ; int used ; } parent_t ;
现在我想声明一个与child_t
具有相同大小的struct parent_t.text
。
我怎样才能做到这一点? (下面的伪码)
typedef struct _child { char flag ; char text[sizeof(parent_t.text)] ; int used ; } child_t ;
我用parent_t
和struct _parent
尝试了几种不同的方法,但是我的编译器不会接受。
作为一个窍门,这似乎工作:
parent_t* dummy ; typedef struct _child { char flag ; char text[sizeof(dummy->text)] ; int used ; } child_t ;
是否有可能宣布child_t
不使用dummy
?
尽pipe使用#define
定义缓冲区大小是一种惯用的方法,但另一种方法是使用这样的macros:
#define member_size(type, member) sizeof(((type *)0)->member)
并像这样使用它:
typedef struct { float calc; char text[255]; int used; } Parent; typedef struct { char flag; char text[member_size(Parent, text)]; int used; } Child;
我实际上有点惊讶, sizeof((type *)0)->member)
甚至允许作为常量expression式。 很酷的东西。
我现在不在我的开发机器上,但我认为你可以做以下其中一项:
sizeof(((parent_t *)0)->text) sizeof(((parent_t){0}).text)
编辑 :我喜欢member_sizemacros乔伊build议使用这种技术,我想我会用这个。
使用预处理器指令,即#define:
#define TEXT_LEN 255 typedef struct _parent { float calc ; char text[TEXT_LEN] ; int used ; } parent_t ; typedef struct _child { char flag ; char text[TEXT_LEN] ; int used ; } child_t ;
您可以使用预处理器指令大小为:
#define TEXT_MAX_SIZE 255
并用于父母和孩子。
另一种可能性是定义一个types。 你想确保两个字段大小相同的事实是一个指标,你有他们相同的语义,我想。
typedef char description[255];
然后有一个领域
description text;
在你的两个types。
struct.h
已经定义了它们,
#define fldsiz(name, field) \ (sizeof(((struct name *)0)->field))
所以你可以,
#include <stdlib.h> /* EXIT_SUCCESS */ #include <stdio.h> /* printf */ #include <struct.h> /* fldsiz */ struct Penguin { char name[128]; struct Penguin *child[16]; }; static const int name_size = fldsiz(Penguin, name) / sizeof(char); static const int child_size = fldsiz(Penguin, child) / sizeof(struct Penguin *); int main(void) { printf("Penguin.name is %d chars and Penguin.child is %d Penguin *.\n", name_size, child_size); return EXIT_SUCCESS; }
但是,在标题中看起来,这是一个BSD的东西,而不是ANSI或POSIX标准。 我在一台Linux机器上试了一下,并没有工作。 有限的用处。
c ++解决scheme:
sizeof(types::成员)似乎也在工作:
struct Parent { float calc; char text[255]; int used; }; struct Child { char flag; char text[sizeof(Parent::text)]; int used; };
您可以在Linux中免费使用sizeof_field(type, filed)
。 它只是定义如下:
#define sizeof_field(type,field) (sizeof(((type *)0)->field))
这是上面提到的。 但是使用已定义的macros更便于使用。
@乔伊亚当斯,谢谢! 我正在寻找同样的东西,但是对于非char数组,它甚至可以用这种方式很好地工作:
#define member_dim(type, member) sizeof(((type*)0)->member) / \ sizeof(((type*)0)->member[0]) struct parent { int array[20]; }; struct child { int array[member_dim(struct parent, array)]; }; int main ( void ) { return member_dim(struct child, array); }
如预期的那样返回20。
而且,@ brandon-horsley,这个作品也很好:
#define member_dim(type, member) sizeof(((type){0}).member) / \ sizeof(((type){0}).member[0])