一文掌握C语言中的柔性数组

 更新时间:2024年03月27日 11:40:34   投稿:mrr  
柔性数组在C语言的 C99 标准中,引入的新特性,结构中的最后一个元素的大小允许是未知的数组,即为柔性数组,本文给大家介绍c语言中的柔性数组,感兴趣的朋友跟随小编一起看看吧

何为柔性数组(Flexible Array)

柔性数组在C语言的 C99 标准中,引入的新特性。结构中的最后一个元素的大小允许是未知的数组,即为柔性数组。

struct S {
	int i;
	int arr[];   //柔性数组成员
	/*int arr[0];*/ //这两种写法都可以,具体看编译器
};

1.柔性数组的特点

  • 柔性数组不能单独的出现在结构体之中,至少要包含一个及以上其它成员,且要在末尾
  • 利用sizeof计算的结构体大小,并不会去计算柔性数组的大小
  • 包含柔性数组成员的结构体要利用malloc来进行动态内存分配,且分配的内存大小要大于结构体内存大小,来达到预期的所需内存的大小。

2.柔性数组的创建和简单使用

创建

struct S {
	int i;
	int arr[];  
};
int main() {
	struct S *s = (struct S*)malloc(sizeof(struct S)+5*sizeof(int));
//使用malloc创建了一个大小为:       (结构体本身大小) + 柔性数组你所期望的大小
    struct S *s = (struct S*)malloc(sizeof(struct S)+10*sizeof(int));
                                                 //调整柔性数组大小
	return 0;
}

这就是为什么柔性数组为什么要在成员末尾的原因,只有它在末尾,开辟内存的大小变化时,柔性数组的大小才会随着变化,这就是所谓的柔性数组

 简单使用

                                                                   代码一

struct S {
	int i;
	int arr[];  
};
int main() {
	struct S *p = (struct S*)malloc(sizeof(struct S)+5*sizeof(int));
    if(p == NULL)
    return 1;
	//业务处理
	p->i = 100;
	for (int i = 0; i < 100; i++)
	{
		p->arr[i] = i;
	}
	//释放空间
	free(p);
	p = NULL;
	return 0;
}

 3.柔性数组的优势

在上柔性数组的简单使用中,我们的代码换种写法也可以达到跟柔性数组一样的功能

把柔性数组成员换成:指针变量

                                                                  代码二

struct S {
	int i;
	int *parr;
};
int main() {
	struct S* p = (struct S*)malloc(sizeof(struct S));
	if (p == NULL)
		return 0;
	p->parr = (int*)malloc(5 * sizeof(int));//多一次malloc就必然要多一次检查和内存释放
	if (p->parr == NULL)                         
		return 0;
	//业务处理
	p->i = 100;
	for (int i = 0; i < 100; i++)
	{
		p->parr = i;
	}
	//释放空间
	free(p->parr);  //得先释放结构体成员parr所指向的空间
	p->parr = NULL;
	free(p);        //在释放p,若顺序弄错造成内存泄露
	p->parr = NULL;
	return 0;
}

说白了就是利用结构体里的指针paar再去开辟一块动态内存空间 

代码一比代码二优势的地方在于:

优势 1 :方便内存释放

使用了较少次的malloc,这样使后面的内存释放得到了方便,且也不容易造成内存泄漏

优势 2 :提升性能

连续的内存有益于提⾼访问速度,也有益于减少内存碎⽚。

到此这篇关于c语言中的柔性数组的文章就介绍到这了,更多相关c语言柔性数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C/C++实现全排列算法的示例代码

    C/C++实现全排列算法的示例代码

    本文主要介绍了C/C++实现全排列算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • C++如何实现DNS域名解析

    C++如何实现DNS域名解析

    这片文章介绍了C++如何实现DNS域名解析,还有对相关技术的介绍,代码很详细,需要的朋友可以参考下
    2015-07-07
  • C++学习进阶篇之类大小计算和this指针

    C++学习进阶篇之类大小计算和this指针

    this是C++中的一个关键字,也是一个const指针,它指向当前对象,通过它可以访问当前对象的所有成员,下面这篇文章主要给大家介绍了关于C++学习进阶篇之类大小计算和this指针的相关资料,需要的朋友可以参考下
    2023-04-04
  • C++利用用埃式筛法求解素数

    C++利用用埃式筛法求解素数

    埃拉托斯特尼筛法,简称埃氏筛或爱氏筛,是一种由希腊数学家埃拉托斯特尼所提出的一种简单检定素数的算法。本文将利用这一算法实现求解素数,感兴趣的可以了解一下
    2023-01-01
  • 解决Visual Studio Code错误Cannot build and debug because the

    解决Visual Studio Code错误Cannot build and debug because 

    这篇文章主要为大家介绍了解决Visual Studio Code错误Cannot build and debug because the及分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • C++基于Boost库实现命令行解析

    C++基于Boost库实现命令行解析

    Boost库中默认自带了一个功能强大的命令行参数解析器,以往我都是自己实现参数解析的,今天偶尔发现这个好东西,就来总结一下参数解析的基本用法,该库需要引入program_options.hpp头文件,即可使用了
    2021-06-06
  • C++设计模式编程中proxy代理模式的使用实例

    C++设计模式编程中proxy代理模式的使用实例

    这篇文章主要介绍了C++设计模式编程中proxy代理模式的使用实例解析,代理模式可以被归类为结构型的设计模式,代理模式主张为对象提供一种代理以控制对这个对象的访问,需要的朋友可以参考下
    2016-03-03
  • C/C++动态分配与释放内存的区别详细解析

    C/C++动态分配与释放内存的区别详细解析

    以下是对C与C++中动态分配与释放内存的区别进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09
  • 实例代码分析c++动态分配

    实例代码分析c++动态分配

    这篇文章主要介绍了c++动态分配的的相关资料,文中代码简单易懂,方便大家更好的学习参考,感兴趣的朋友可以了解下
    2020-06-06
  • C++模板二段名字查找方法

    C++模板二段名字查找方法

    下面小编就为大家带来一篇C++模板二段名字查找方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01

最新评论