结构体中的变长数组

本文深入探讨了可变长度结构体的定义与实现方式,通过实例展示了如何利用空数组来创建可变长结构,阐述了这种方法的优点,并提供了一段简洁的代码示例,演示了如何在内存中分配所需空间并进行访问。此外,文章还讨论了这种方法在防止内存泄漏和简化代码方面带来的便利。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时我们需要产生一个结构体,实现了一种可变长度的结构。如何来实现呢?
看这个结构体的定义:
typedef struct st_type
{
    int nCnt;
    int item[0];
}type_a;

(有些编译器会报错无法编译可以改成:)
typedef struct st_type
{
    int nCnt;
    int item[];
}type_a;

这样我们就可以定义一个可变长的结构,用sizeof(type_a)得到的只有4,就是sizeof(nCnt)=sizeof(int)那个0个元素的数组没有占用空间,而后我们可以进行变长操作了。

优点:
1.不需要初始化,数组名直接就是所在的偏移 
2.不占任何空间,指针需要占用int长度空间,空数组不占任何空间。


“这个数组不占用任何内存”,意味着这样的结构节省空间;“该数组的内存地址就和他后面的元素的地址相同”,意味着无需初始化,数组名就是后面元素的地址,直接就能当做指针使用。

type_a *p = (type_a *)malloc(sizeof(type_a) + 100 * sizeof(int));

free(p);

这样我们就产生了一个长为100的type_a类型的东西用p->item[n]就能简单地访问可变长元素,原理十分简单
,分配了比sizeof(type_a)多的内存后int item[];就有了其意义了,它指向的是intnCnt;后面的内容,是没
有内存需要的,而在分配时多分配的内存就可以由其来操控,是个十分好用的技巧。

一次分配解决问题,省了不少麻烦。大家知道为了防止内存泄漏,如果是分两次分配(结构体和缓冲区),那么要是第二次malloc失败了,必须回滚释放第一个分配的结构体。这样带来了编码麻烦。其次,分配了第二个缓冲区以后,如果结构里面用的是指针,还要为这个指针赋值。同样,在free这个p的时候,用指针也要两次free。如果用空数组,所有问题一次解决。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值