malloc、calloc、realloc三个函数的认识

内存分配有三种方式
1. 从静态存储区分配,生命周期随程序的结束而结束,比如全局变量,静态变量。
2. 从栈空间分配,函数调用结束后自动释放。
3. 从堆空间分配,即动态内存开辟,如malloc、calloc、realloc。
(1) malloc:
函数原型:void* malloc(size_t size)
这个函数向内存申请一块连续的空间,并返回指向这块空间的地址。
—如果开辟成功,则返回指向开辟好空间的地址;
—如果开辟失败,则返回空指针,所以使用malloc必须检查开辟是否成功;
—返回的类型为void*,所以malloc并不知道所开辟空间的类型,需要进行类型转换;
—如果参数size为0,malloc的行为是没有定义的,取决于编译器;
—free不改变指针的地址,free后目标指针变为野指针,需要置为NULL;
—malloc申请的空间可以用memset函数初始化;
(2) calloc:
函数原型:void* calloc(size_t num, size_t size)
—第一个参数是需要开辟多少个元素,即元素的个数,第二个参数是每个元素的大小,乘积为所开辟空间的大小;
—与malloc不同的是calloc在开辟空间的同时将其每个字节的内容初始化为0;
(3) realloc:
函数原型:void* realloc(void* memblock, size_t size)
—第一个参数是指向先前分配内存块的指针,第二个参数是需要开辟的内存的字节大小;
—realloc不能保证调整后的内存空间的地址不发生改变,完全可能指向一块新的空间;
—realloc是从堆上分配内存的,扩大一块内存空间时,当堆上空间足够大且满足扩大要求时,就在原来的基础上扩大字节数,返回原来的地址,否则会在其他足够大的空间开辟空间,并将原来的数据拷贝到新的位置,返回新地址,即realloc可能发生数据搬移;
(4) 常见内存错误
—内存未成功开辟,却进行使用;如果是传参问题,应用assert进行断言;如果用malloc开辟空间,应用if语句判断使用;
—内存分配成功但没有初始化;
—忘记释放内存,造成内存泄露;(malloc与free需成对使用)
—释放了内存却依然使用它;
—不要返回指向“栈内存”的“指针”或者“引用”,因为该内存在函数体结束时被自动销毁;
—使用free函数释放后未将其置为空指针,产生“野指针”;

猜你喜欢

转载自blog.csdn.net/C1029323236/article/details/80637178
今日推荐