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函数释放后未将其置为空指针,产生“野指针”;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值