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;
}

代码验证:

相关推荐
养军博客7 分钟前
C语言五天算法速成(可用于备考蓝桥杯)
c语言·算法·蓝桥杯
无限进步_12 分钟前
203. 移除链表元素 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
10岁的博客33 分钟前
C语言造轮子大赛
java·c语言·数据结构
你怎么知道我是队长39 分钟前
C语言---排序算法1---冒泡排序法
c语言·算法·排序算法
历程里程碑40 分钟前
Linux 9:GCC编译全流程详解
linux·运维·服务器·c语言·笔记·编辑器·vim
Once_day44 分钟前
C++之《Effective C++》读书总结(1)
c语言·c++·effective c++
爱吃生蚝的于勒1 小时前
【Linux】进程信号的保存(二)
linux·运维·服务器·c语言·数据结构·c++·算法
小程同学>o<1 小时前
嵌入式之C/C++(一)关键字
c语言·开发语言·c++·嵌入式软件面试
郝学胜-神的一滴2 小时前
Linux Socket编程核心:深入解析sockaddr数据结构族
linux·服务器·c语言·网络·数据结构·c++·架构
云深麋鹿3 小时前
五.排序笔记
c语言·数据结构·算法·排序算法