对于某些情况,我们不易判断出某个数组中元素的个数。例如利用网络通信获取某个列表,这个列表可长可短。 这种情况可以考虑使用大小可变结构体,形如:
typedef struct tag_ST1
{
int nCount;
int items[0];
} ST1;
nCount标识items中元素的数量,如果只求结构体ST1的size,只会得到nCount的占用空间的size。
使用方法,可参考如下代码:
#include<stdio.h>
#include<stdlib.h>
// 大小可变结构体
typedef struct tag_ST0
{
int items[0];
} ST0;
typedef struct tag_ST1
{
int nCount;
int items[0];
} ST1;
typedef struct tag_ST2
{
int nCount;
char items[0];
} ST2;
int main ()
{
int i;
printf("ST0 size:%d\n", sizeof(ST0));
printf("ST1 size:%d\n", sizeof(ST1));
printf("ST2 size:%d\n", sizeof(ST2));
ST1 *p = (ST1*) malloc(sizeof(ST1) + 100 * sizeof(int));
p->nCount = 100;
for (i = 0; i < 100; i++)
{
p->items[i] = i;
}
for (i = 0; i < 100; i++)
{
printf("ST1->items[%d]=%d\n", i, p->items[i]);
}
free(p);
return 0;
}
执行结果如下: ST0 size:0 ST1 size:4 ST2 size:4 ST1->items[0]=0 ST1->items[1]=1 ST1->items[2]=2 ..... ST1->items[98]=98 ST1->items[99]=99 ?
|