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

代码验证:

相关推荐
我不会插花弄玉21 分钟前
vs2022调试基础篇【由浅入深-C语言】
c语言
福尔摩斯张1 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
fashion 道格1 小时前
数据结构实战:深入理解队列的链式结构与实现
c语言·数据结构
铁手飞鹰2 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
[J] 一坚4 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
散峰而望6 小时前
C++数组(一)(算法竞赛)
c语言·开发语言·c++·算法·github
自然常数e6 小时前
深入理解指针(1)
c语言·算法·visual studio
hazy1k8 小时前
ESP32基础-Socket通信 (TCP/UDP)
c语言·单片机·嵌入式硬件·网络协议·tcp/ip·udp·esp32
dvvvvvw8 小时前
x的y次幂的递归函数.c
c语言
Want59511 小时前
C/C++跳动的爱心②
c语言·开发语言·c++