动态内存管理
头文件 malloc.h 或者 stdlib.h;
malloc 接口 申请 free释放
int arrary= (int*) malloc(nsizeof( int));malloc 的返回值 为 void;开辟失败,返回NULL;
free(NULL 或者malloc 的返回指针)
free的操作注意点 : 不能部分释放 ;申请多少,释放多少,编译可以通过,但运行一点出错;free(NULL)永真;
2 calloc 接口, 申请时并初始化0;calloc(元素数量,每个元素的字节数)
realloc :
对已申请的内存做修改:扩展和缩小
扩展:原先内容仍旧保留,
缩小:去尾;
int* array1= realloc(array被操作数组,调整后的大小);
注意 :realloc 函数的地址可能会变 :
因为:内存(堆)不够大时,编译器就会去寻找 合适 的内存大小的地方 去开辟;所以地址可能 会改变;
若是改变,原来的指针(申请的内存块)将被realloc接口释放掉;被释放的空间不能重复释放;
在这里 我们发现 栈是向下生长的(栈顶是高地址);堆是向上生长的
注意 :动态分配内存是在堆上进行的
alloc 函数是在栈上动态申请空间的, afree()函数释放空间的
,不同的是, afree得先来,alloc后来。