动态内存分配机制和案例
动态内存分配机制
案例
#include<stdib.h>
#include<stdio.h>
int main(){
void check(int*);//函数声明
int*p,i;
//在堆区开辟一个5*4的空间
p=(int*)malloc(5*sizeof(int));//void*-->int*[c99]
for(i=0;i<5;i++){
scanf("%d",p+i);
}
check(p);
free(p);//销毁堆区p指向的空间
getchar();
getchat();
return 0;
}
void check (int*p){
int i;
printf("\n不及格的成绩有:");
for(i=0;i<5;i++){
if(p[i]<60){
printf("%d",p[i]);
}
}
}
注意事项
1)避免分配大量的小内存
2)使用完堆上的内存块,就需要即使释放动态分配内存,需要遵守远测:谁分配,谁释放
3)确保不会无意中覆盖堆上已分配的内存,避免出现内存泄漏。在循环中分配内存要特别小心。
指针使用一览