「这是我参与2022首次更文挑战的第11天,活动详情查看:2022首次更文挑战」。
动态内存分配
传统数组的缺点:
1、数组长度必须事先制定,且只能是常整数,不能是变量
例子:int a[3];//OK
int len = 3;int a[len];//error
2、传统形式定义的数组,该数组的内存程序员无法手动释放
数组一旦定义,系统为该数组分配的存储空间就会一直存在,
除非数组所在函数运行结束
在一个函数运行期间,系统为该函数中数组所分配的空间会一直存在,知道该函数运行完毕时,数组的空间才会释放。
3、数组的长度一旦定义,其长度就不能再更改
数组的长度不能再函数运行的过程中动态的扩充或缩小
4、A函数定义的数组,在A函数运行期间可以被其他函数使用,但A函数运行完毕之后,A函数中的数组将无法再被其他函数使用
举个例子
# include<stdio.h>
void g(int * pArr,int len)
{
pArr[2] = 88;
}
void f(void)
{
int a[5] = {1,2,3,4,5};
g(a,5);
printf("%d\n",a[2]);
}
int main(void)
{
f();
return 0;
}
如果释放了f();则数组a[]也不能使用
为什么需要动态分配内存
动态数组很好的解决了传统数组的这4个缺陷
传统数组也叫静态数组
动态内存分配举例_动态数组的构造
12行分配了8个字节,p变量占4个字节,p所指向的内存也占4个字节
p本身所占的内存是静态分配的,p所指向的内存是动态分配的
#include<stdio.h>
#include<malloc.h>
void f(int * q)
{
//*p=200;//error
//q = 200;
//**q = 200;//error
*q = 200;
free(q);//把q所指向的内存释放
}
int mian(void)
{
int * p = (int *)malloc(sizeof(int));
*p = 10;
printf("%d\n",*p);//10
f(p);
printf("%d\n",*p);//200
return 0;
}
静态内存和动态内存的比较
静态内存是由系统自动分配,由系统自动释放
静态内存是在栈分配的。
动态内存是由程序员手动分配,手动释放
动态内存是在堆分配的。
还有一些不太重要的内容后面会一一补充。