C语言 ——— 柔性数组

目录

柔性数组的概念以及定义

柔性数组的特点

柔性数组的使用


柔性数组的概念以及定义

概念:

C99中,结构中的最后一个元素允许是未知大小的数组,这就叫柔性数组成员

定义:

复制代码
struct st_type
{
	int i;
	int a[0]; //柔性数组成员
};

当以上代码形式编译不通过时,可改为一下代码形式

复制代码
struct st_type
{
	int i;
	int a[]; //柔性数组成员
};

柔性数组的特点

1. 结构中的柔性数组成员前面必须至少有一个其他成员

2. sizeof 计算的这种结构大小不包括柔性数组的内存

代码验证:

3. 包含柔性数组成员的结构用 malloc 函数进行内存的动态分配,并且分配的内存应该大于结构体的大小,以适应柔性数组的预期大小

代码演示:

复制代码
#include<stdio.h>
typedef struct st_type
{
	int i;
	int a[0]; //柔性数组成员
}ST;
int main()
{
	//                     4       +       40
    ST* s = (ST*)malloc(sizeof(ST) + sizeof(int) * 10);

	return 0;
}

柔性数组的使用

代码演示:

复制代码
#include<stdio.h>
#include<stdlib.h>
typedef struct st_type
{
	int sz;
	int a[0]; //柔性数组成员
}ST;
int main()
{
	//                     4       +       40
	ST* s = (ST*)malloc(sizeof(ST) + sizeof(int) * 10);

	// 判断是否开辟成功
	if (s == NULL)
	{
		perror("malloc");
		return -1;
	}

	// 赋值
	s->sz = 10;

	for (int i = 0; i < s->sz; i++)
	{
		s->a[i] = i;
	}

	// 打印验证
	printf("%d\n", s->sz);

	for (int i = 0; i < s->sz; i++)
	{
		printf("%d ", s->a[i]);
	}

	// 释放动态开辟的内存空间
	free(s);
	s = NULL;

	return 0;
}

代码验证:

相关推荐
-dzk-12 小时前
【代码随想录】LC 203.移除链表元素
c语言·数据结构·c++·算法·链表
进击的小头13 小时前
陷波器实现(针对性滤除特定频率噪声)
c语言·python·算法
寄存器漫游者14 小时前
数据结构 C语言 顺序栈
java·c语言·数据结构
日拱一卒——功不唐捐14 小时前
循环队列+双端队列(C语言)
c语言·数据结构
进击的小头14 小时前
设计模式组合应用:嵌入式通信协议栈
c语言·设计模式·策略模式
养军博客14 小时前
C语言五天速成(可用于蓝桥杯备考 难度中等偏下)
c语言·算法·蓝桥杯
leaves falling15 小时前
c语言单链表
c语言·开发语言
请注意这个女生叫小美15 小时前
C语言实例22 乒乓球比赛
c语言
方便面不加香菜15 小时前
数据结构--链式结构二叉树
c语言·数据结构
Tingjct16 小时前
十大排序算法——交换排序(一)
c语言·开发语言·数据结构·算法·排序算法