一、引言
为什么要进行动态内存分配?
以数组为例,数组元素在内存中存储的地址是连续的。声明一个数组后,该数组需要的内存大小在程序编译时就被分配,但是该数组实际所需内存大小在程序运行时才知道,若运行时发现数组所需内存大于编译时的分配好的数组内存,就会报错,示例程序如下:
#include <stdio.h>
int main(void)
{
int arr[5];
for (int i = 0; i < 10; i++)
scanf("%d", &arr[i]);
for (int i = 0; i < 10; i++)
printf("%d ", arr[i]);
printf("\n");
return 0;
}
首先声明了有5个元素的数组arr,但是在实际输入时输入了10个元素,也就是说编译器在编译时给arr分配了5个int型大小的内存块,但是在运行时需要10个int型大小的内存块,此时数组越界,就会报错误。
为了解决上述问题,就需要动态分配内存,所谓动态分配内存,通俗理解是需要多大的内存,就分配多大的内存。
在C语言中,与动态内存分配有关的函数为malloc、calloc、realloc、free,这些函数在库文
<stdlib.h>中声明;
C++中,与动态内存分配有关的运算符为new、delete。