【c语言】大小可变结构体

对于某些情况,我们不易判断出某个数组中元素的个数。例如利用网络通信获取某个列表,这个列表可长可短。
这种情况可以考虑使用大小可变结构体,形如:

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
 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值