C语言内存分配

在堆上分配内存:malloc() calloc() realloc() 和 free()

1.malloc()

#include<stdio.h>

void* malloc(size_t size);

        malloc()函数在堆上分配参数size字节大小的内存,并且返回指向新分配内存起始位置处的指针,其所分配的内存没有初始化。

        由于malloc()的返回类型为void*,因而可以将其赋值给任意类型的指针。

2.free()

#include<stdlib.h>

void free(void*ptr);

        free()函数释放的ptr参数所指向的内存块,该参数之前是由malloc(),calloc(),realloc()函数所返回的地址。

        如果传给free()的是一个空指针,那么函数将什么都不做。(换句话说,给free()传入一个空指针并不是错误代码)。

        在调用free()对ptr指针指向的内存块释放后,再次将ptr参数传递给free(),将产生错误。

3.calloc()

#include<stdlib.h>

void* calloc(size_t numitems,size_t size);

        calloc()函数用于分配一个包含指定数量元素的内存块,第一个参数numitems指定分配对象的数量,第二个参数size指定每个对象的大小。在分配了适当大小的内存块后,calloc()函数返回指向这块内存起始处的指针(如果无法分配内存,则返回NULL),与malloc()不同,calloc会将已分配的内存初始化为0.

4.realloc()

#include<stdlib.h>

void* realloc(void* ptr,size_t size);

        realloc()函数用于更改先前分配的内存块的大小。第一个参数ptr是指向所需要调整大小的内存块的指针,第二个参数size指定调整后内存块期望大小。

        如果内存重新分配成功,realloc()返回指向调整大小后的内存块的指针,与调用前的指针相比,二者指向的位置可能不同。如果失败,realloc()返回NULL,并且ptr所指向的原始内存块原封不动,不会被释放。

注意:

        由于realloc()可能会移动内存,所以不能直接把realloc()的返回值直接赋给ptr,因为一旦调用realloc()失败,那么ptr会被置为NULL,从而无法访问现有内存块造成内存泄漏。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值