1)全局变量——内存中的静态存储区
2)非静态的局部变量——内存中的动态存储区——stack 栈
3)临时使用的数据—建立动态内存分配区域,需要时随时开辟,不需要时及时释放——heap 堆
4)根据需要向系统申请所需大小的空间,由于未在声明部分定义其为变量或者数组,不能通过变量名或者数组名 来引用这些数据,只能通过指针来引用)
1)头文件 #include <stdlib.h> 声明了四个关于内存动态分配的函数
2)函数原型 void * malloc(usigned int size) //memory allocation
3)函数原型 void *calloc(unsigned n,unsigned size)
4)函数原型:void free(void *p)
5) 函数原型 void *realloc(void *p,unsigned int size)
6)返回类型说明
动态创建数组,输入 5 个学生的成绩,另外一个函数检测成绩低于 60 分的,输出不合格的成绩。
代码演示
#include <stdlib.h> #include <stdio.h> int main() { void check(int *); int * p,i; // 在堆区开辟一个 5 * 4 的空间,并将地址 (void *) , 转成 (int *) , 赋给 p p = (int *)malloc(5*sizeof(int)); for( i = 0; i < 5; i++) { scanf("%d", p + i); } check(p); // free(p); //销毁 堆区 p 指向的空间 getchar(); getchar(); 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)总是确保释放以分配的内存。在编写分配内存的代码时,就要确定在代码的什么地方释放内存
4)在释放内存之前,确保不会无意中覆盖堆上已分配的内存地址,否则程序就会出现内存泄漏。在循环中分配内 存时,要特别小心
5)指针使用一览