引言:为什么使用动态内存分配
当你声明数组时,你必须用一个编译时常量指定数组的长度。但是,数组的长度常常在运行时才知道,这是由于它所需要的内存空间取决于输入数据。例如,一个用于计算学生等级和平均分的程序可能需要存储一个班级所有学生的数据,但不同班级的学生数量可能不同。在这些情况下,我们通常采用的方法是声明一个较大的数组,它可以容纳可能出现的最多元素。
这种方法简单,但也有好几个缺点:
- 缺点1、这种声明在程序中引入了人为的限制,如果程序需要使用的元素数量超过了声明的长度,它就无法处理这种情况。要避免这种情况,显而易见的方法是把数组声明的更大一些,但这种做法使他的第2个缺点进一步恶化。
- 缺点2、如果程序实际需要的元素数量比较少时,巨型数组的绝大部分内存空间都被浪费了。
- 缺点3、如果输入的数据超过了数组的容纳范围时,程序必须以一种合理的方式作出响应,它不应该由于一个异常而失败。但也不应该打印出看上去正确实际上却是错误的结果。
malloc函数和free函数头文件
#include<stdlib.h> 或者 #include<malloc.h>
原型
extern void * malloc(unsigned int num_byte);
- 功能:分配长度为num_byte字节的内存块
- 参数:需要分配
本文深入探讨了动态内存分配的重要性,特别是在数组长度不确定的情况下的应用。介绍了malloc和free函数的使用,包括函数原型、注意事项和常见错误,强调了内存泄漏的危害,并提供了编程提示。
订阅专栏 解锁全文
8899

被折叠的 条评论
为什么被折叠?



