动态内存的优点: 1.可以在程序运行期间,动态的确定开辟内存的大小 2.可以开辟大的内存块(堆的可开辟大小可在项目属性中的链接器中修改)
动态内存主要使用到4个包含在stdlib.h库中的malloc()、calloc()、realloc()、free()函数。
函数声明信息:
void *malloc(size_t size); //所需内存大小 初始单位为B
void free(void *ptr); //传入手动开辟内存的首地址
void *calloc(size_t nmemb, size_t size); //前为块内存个数,后为块内存大小
void *realloc(void *ptr, size_t size); //需要重新分配的内存地址,重新分配长度
malloc:分配内存块 calloc:分配内存块,并且全部初始化为0 ? (一般用malloc+for代替calloc) realloc:调用之前申请的内存块的大小(可扩充,可缩小) realloc缩小内存块的话,开头地址不变,并且其他不要的数据,也没有变化,只是右边界线缩小释放:free(),参数一定是开辟的内存块的开始地址
1.free函数的必要性:如果动态内存开辟,而使用结束后,没有释放,会导致申请的这块内存没有人可以使用 ? 一般将这快没有人可以使用的内存叫做“垃圾”,留着垃圾的函数或者程序,会导致出现内存泄露
2.一个malloc搭配一个free
c语言有两个东西,特别危险: ? 1.数组越界 ? 2.内存泄露 ?? ? free函数的情况: ? 1.同一块内存连续释放(运行直接报错) ? 2.free释放内存块A,但其参数,并不是A的开始地址(越界释放,运行报错) ? 3.free结束后,会造成一个悬空指针 ? 一般来说,free函数执行结束后,会立刻手动将其变成空指针
这里也可以涉及到悬空指针以及空指针的相关知识。
悬空指针和空指针的区别: 空指针:指向0地址的指针 ? 非NULL即真 悬空指针:(野指针),这个指针可以能会指向任何一个空间,有修改的风险,会造成不可知的错误
//内存泄露或者内存碎片怎么处理:重启(解决90%问题? ?狗头)
|