一、动态内存分配原理
当我们想突破函数内局部变量的作用域局限,完全拥有由我们自己控制生死的内存地址(由指针指向的),
这时候,你可以声明一个指针,让指针指向使用神奇的malloc 函数申请的“活”(动态)内存,
申请时,记得告诉malloc 你需要的内存大小(指针指向变量所占内存空间大小),
这样,你就可以像往常一样操作指针使用这段内存了,
不同的是,它的生死完全由你控制,让它消失,你只要 free 它。
二、实例说明
//定义一个固定数组,赋值0-9:
int main(){
int a[10];
int i;
for(i = 0; i < 10; i++){
a[i] = i;
}
for(i = 0; i < 10; i++){
printf("a[%d] = %d\n",i,a[i]);
}
return 0;
}
上面的代码是一个数组:0,1,2,3,4,5,6,7,8,9
我们通过动态内存来实现:
//分配一个动态内存,10个整型数的空间,每个空间也赋值,实现跟上相同的功能:
//局部变量,值传递完,函数的栈内存空间也跟着释放掉
//而动态内存空间不会,除非手动释放掉,相当于全局变量。
int main(){
int *p = NULL;
p = malloc(sizeof(int) * 10); //分配一个40字节的内存
for(int i = 0; i < 10; i++){
*(p+i) = i; //指针根据i值来自增 写成 p[i] = i;也是一样
}
for(int i = 0; i < 10; i++){
printf("%d\n",*(p+i));
}
return 0;
}
上面的代码实现的功能跟前面的一模一样。
还有个好处就是完全拥有由我们自己控制,可以随便修改内存的大小:
int main(){
int *p = NULL;
p = malloc(sizeof(int) * 10);
int count = 15; //可以通过改变count的值来改变分配内存的大小
free(p); //释放内存
p = malloc(sizeof(int) * count);
for(int i = 0; i < count; i++){
*(p+i) = i;
}
for(int i = 0; i < count; i++){
printf("%d\n",*(p+i));
}
return 0;
}