C语言学习
可变数组
在我们写程序时,我们一般需要储存我们接收到的数据。使用数组去储存很方便。
当当我们程序写下构建后烧录到单片机上时,如果数据过多数组当前的大小无法储存更多的数据,
那此时我们就不得不更改代码,选用更大的数组去储存数据。
但当大小仍不够用时,就不得不重复上述的操作了。若我们能让存储数据的数组随数据增多而增大,
那么就可以解决上述的问题。
我们可以通过不断地利用malloc申请储存空间来实现可变数组的功能。
可变数组代码:
通过调用该模块化后的函数就可以实现可变数组的功能。
代码详解请参考注释。
注:我们是调用void array_inflate(Array* a, int more_size)这一部分的代码来实现增大储存空间
的。但因为执行程序的顺序,我们首先要将上次申请的储存空间内储存的数据转移到新
申请的空间内。所以每次申请新的储存空间前,我们不能free上次申请的储存空间,
这就意味着我们每次新malloc的空间都是接在在上次malloc的空间之后,这就导致我们浪费了大量的储存空间,没能使用。
而我们使用的单片机的存储空间只有几MB大小。所以我们要寻求新的办法。而这个办法就是下节要讲的链表。
相关知识笔记:
|