C语言编程C++柔性数组结构示例讲解

 更新时间:2021年09月28日 09:00:59   作者:小码农UU  
这篇文章主要介绍了C语言编程系列中的柔性数组,文中含有详细的示例代码讲解,有需要的朋友可以借鉴参考下,希望能够有所帮助

绕指柔—柔性数组

也许你从来没有听说过柔性数组(flexible array)这个概念,但是它确实是存在的。 C99 中,结构体中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员。

柔性数组的特点:

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

2.sizeof 返回的这种结构大小不包括柔性数组的内存。

image-20210922062118298

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

image-20210922063451309

那我们如何使用呢

image-20210925215752477

法一

#include<stdio.h>
#include<stdlib.h>
struct S
{
	int a;
	int arr[];//未知大小 柔性数组成员  数组的大小是可以调整的
};
int main()
{
	//我们怎么开辟呢
	//包含柔性数组成员的结构体的使用,要配合malloc这样的动态内存分配内存函数使用
	struct S* ps = (struct S*)malloc(sizeof(struct S) + 5 * sizeof(int));
	//我们如何使用呢
	ps->a = 100;
	int i = 0;
	for (i = 0; i < 5; i++)
	{
		ps->arr[i] = i;
	}
	//还想扩大呢
	struct S* ptr = (struct S*)realloc(ps, sizeof(struct S) + 10 * sizeof(int));//先交给ptr,防止内存调整失败
	if (ptr == NULL)//判断是否开辟成功
	{
		printf("扩容失败\n");
		return 0;
	}
	else
	{
		ps = ptr;
		for (int i = 5; i < 10; i++)
		{
			ps->arr[i] = i;
		}
		for (int i = 0; i < 10; i++)
		{
			printf("%d ", ps->arr[i] = i);
		}
		//用完就释放
		free(ps);
		ps = NULL;
	}	
	return 0;
}

法二

image-20210922071448537

image-20210925223935303

#include<stdio.h>
#include<stdlib.h>
struct S
{
	int a;
	int* parr;
};
int main()
{
	//我们怎么开辟呢
	struct S* ps = (struct S*)malloc(sizeof(struct S));
	//我们如何使用呢
	ps->a = 100;
	ps->parr = (int*)malloc(5 * sizeof(int));
	int i = 0;
	for (i = 0; i < 5; i++)
	{
		ps->parr[i] = i;
	}
	//还想扩大呢
	int* ptr = (int*)malloc(10 * sizeof(int));//先交给ptr,防止内存调整失败
	if (ptr == NULL)//判断是否开辟成功
	{
		printf("扩容失败\n");
		return 0;
	}
	else
	{
		ps->parr = ptr;
		for (int i = 5; i < 10; i++)
		{
			ps->parr[i] = i;
		}
		for (int i = 0; i < 10; i++)
		{
			printf("%d ", ps->parr[i] = i);
		}
		//用完就释放
		free(ps->parr);
		ps->parr = NULL;
		free(ps);
		ps = NULL;
	}	
	return 0;
}

那上面那个方法好一点呢

第一个好处是:方便内存释放

如果我们的代码是在一个给别人用的函数中,你在里面做了二次内存分配,并把整个结构体返回给用户。用户调用free可以释放结构体,但是用户并不知道这个结构体内的成员也需要free,所以你不能指望用户来发现这个事。所以,如果我们把结构体的内存以及其成员要的内存一次性分配好了,并返回给用户一个结构体指针,用户做一次free就可以把所有的内存也给释放掉。

第二个好处是:这样有利于访问速度

连续的内存有益于提高访问速度,也有益于减少内存碎片。(其实,我个人觉得也没多高了,反正你跑不了要用做偏移量的加法来寻址)

总结

第一种好,不好的话,要柔性数组干吗?是不是
何意百炼刚,化为绕指柔

首先说明一下我不软弱,只是单纯觉得这句诗好玩,我不认为这首诗是软弱的诗我有自己的见解。说软弱的只能说不要你想的就是你想的。

以上就是C语言编程之柔性数组示例讲解的详细内容,更多关于C语言柔性数组的资料请关注脚本之家其它相关文章!

相关文章

  • 一文掌握C++ 中使用变量从定义到实践

    一文掌握C++ 中使用变量从定义到实践

    变量是用于存储数据值的容器,在 C++ 中,有不同类型的变量(使用不同的关键字定义),这篇文章给大家介绍C++ 中使用变量从定义到实践记录,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • C语言中结构体(struct)的几种初始化方法

    C语言中结构体(struct)的几种初始化方法

    相信大家都知道struct结构体是C语言中非常重要的复合类型,初始化的方法很多,那么小编下面对这些方法进行总结,便于自己和大家以后查阅,有需要的可以参考借鉴。
    2016-08-08
  • C/C++ Qt 基本文件读写的基本使用(2种实现)

    C/C++ Qt 基本文件读写的基本使用(2种实现)

    文件的读写是很多应用程序具有的功能,本文主要介绍了两种实现方法,第一种使用QFile类的IODevice读写功能直接读写,第二种是利用 QFile和QTextStream结合起来,用流的方式进行文件读写
    2021-11-11
  • C语言实现散列表(哈希Hash表)实例详解

    C语言实现散列表(哈希Hash表)实例详解

    这篇文章主要介绍了C语言实现散列表(哈希Hash表)实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • C++之拼接长字符串问题

    C++之拼接长字符串问题

    这篇文章主要介绍了C++之拼接长字符串问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • OpenCV图像处理基本操作详解

    OpenCV图像处理基本操作详解

    这篇文章主要为大家详细介绍了OpenCV图像处理基本操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • C语言二叉树的概念结构详解

    C语言二叉树的概念结构详解

    二叉树可以简单理解为对于一个节点来说,最多拥有一个上级节点,同时最多具备左右两个下级节点的数据结构。本文将详细介绍一下C++中二叉树的实现和遍历,需要的可以参考一下
    2022-08-08
  • C/C++实现手写数字识别的示例详解

    C/C++实现手写数字识别的示例详解

    这篇文章主要为大家详细介绍了如何使用C/C++实现手写数字识别,分别处理 32*32 文本数据集和mnist 28*28 png数据集,感兴趣的小伙伴可以跟随小编一起了解一下
    2023-10-10
  • C++模版函数详解

    C++模版函数详解

    C++中的模版总体可以分为两大类:模版函数、模版类。本篇文章先写模版函数,需要的朋友可以参考下
    2017-02-02
  • 使用OpenCV实现检测和追踪车辆

    使用OpenCV实现检测和追踪车辆

    这篇文章主要为大家详细介绍了使用OpenCV实现检测和追踪车辆,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01

最新评论