目录

1.动态内存分配的定义
平常我们定义的数组,都是在栈区分配的空间,都是分配的空间都是固定的大小
这种分配固定大小的内存分配方法称之为静态内存分配
与静态内存相对的,就是可以控制内存的分配的动态内存分配
一般开辟空间的方式开辟的空间大小都是固定的,动态内存分配的大小是可变的,灵活。
2.为什么要使用动态内存分配
当我们在声明一个数组的时候,大多情况下我们无法真正得知数组的真实长度,只有在程序运行过程当中我们才可能得知,因此之前设定数组长度时我们往往用一个很大的数组长度来解决这个问题
eg:
char arr[100]={0};
但是这样解决问题的方式依然过于粗糙和不便捷,虽然非常简单,但是如果数组长度不够程序会出错,如果数组长度过大会造成不必要的内存损失,因此我们便引出了动态内存分配来解决这个问题。
eg:
int *a=(int*)malloc(n*sizeof(int));
动态内存分配允许在程序运行时根据需要分配和释放内存,解决了预设数组长度可能导致的不灵活性和资源浪费问题。例如,当数组长度未知时,使用`malloc`函数可以根据实际需求分配内存,避免了过大或过小带来的问题。
1949

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



