C语言学习记录——动态内存函数介绍(malloc、free、calloc、realloc)

简介: C语言学习记录——动态内存函数介绍(malloc、free、calloc、realloc)

内存分区

malloc(开辟空间)

函数介绍

malloc是一个申请内存的函数,size表示要申请的内存的空间大小。这个函数的返回值有两种情况,一是在成功申请空间时,返回一个指向这个空间起始地址的void型指针变量;二是当可用内存不足,内存申请失败,则是返回NULL。

函数用法

int arr[10] = {0} //10int等于10 * sizeof(int)
//使用malloc函数来开辟这段空间
int *p = ( int* )malloc(10 * sizeof(int));

free(释放空间)

函数介绍

free函数是用来释放动态开辟的内存。

如果参数memblock指向的空间不是动态开辟的,则这个行为是错误的。(或者说free函数的行为是未定义的)

如果参数memblock是NULL指针,则free函数不起任何作用。

函数用法

结合前面的malloc,来看他们各自的用法。

#include <stdio.h>
#include <stdlib.h>
int main()
{
    //int arr[10] = { 0 };在栈区
    int* p = (int*)malloc(10 * sizeof(int));//动态内存开辟的,在堆区
    //在使用这些内存的时候,判断一下是否开辟成功了
    if (p == NULL)
    {
        //报错
        perror("main");//main:报错内容
        return 0;
    }
    //使用
    int i = 0;
    for (i = 0; i < 10; i++)
    {
        *(p + i) = i;
    }
    //打印一下这个数组
    for (i = 0; i < 10; i++)
    {
        printf("%d ", p[i]);//p[i]等价于 *(p + i)
    }
    //回收空间(释放空间)
    free(p);
    //free释放空间之后不会把指针p赋为空指针
    //如果后面又使用到指针p的话就会造成非法访问内存
    //所以我们需要手动赋成空指针
    p = NULL;
    return 0;
}

运行结果:

如果可用内存不足,内存开辟失败,运行情况则为:

一般地,malloc和free是成对出现的。

calloc(开辟空间)

函数介绍

calloc函数也是用于动态内存分配的,其功能是为num个size大小的元素开辟一块空间,并且把空间的每个字节初始化为0.

与malloc函数主要有两个区别:

  • 函数参数有两个
  • 会进行初始化

函数用法(对比malloc)

realloc(调整空间)

函数介绍

realloc函数的作用是让动态内存管理更加灵活,它可以做到对动态开辟内存大小的调整。

memblock是要调整的内存地址size表示调整之后的新大小

realloc函数同样返回一个void型的指针,指向调整之后的新空间的起始地址

这里 新空间的起始地址有两种情况:

  • 一是原有的空间后面有足够大的空间去给realloc去调整。
  • 二是原有的空间后面没有足够大的空间去给realloc去调整。

而当realloc在堆区已经找不到可以供原有空间进行调整的多余空间时,它就会返回一个NULL指针。


如果我们拿原地址p去接受realloc返回的地址,就有"偷鸡不成蚀把米"的风险,即调整不成功反而把原有的空间丢失了。所以一般地,创建一个临时变量用来存储realloc返回的地址,确认其调整成功之后再赋给p。

函数用法

#include <stdio.h>
#include <stdlib.h>
int main()
{
    //申请了10个int型的空间
    int* p = (int*)calloc(10, sizeof(int));
    int i = 0;
    for (i = 0; i < 10; i++)
    {
        *(p + i) = 6;
    }
    //现在我们要调整为20个int
    int* ptr = (int*)realloc(p, 20 * (sizeof(int)));//创建临时变量ptr
    if (ptr != NULL)//判断是否调整成功
    {
        p = ptr;
    }
    for (i = 10; i < 20; i++)
    {
        *(p + i) = 6;
    }
    for (i = 0; i < 20; i++)
    {
        printf("p[%d] = %d\n",i+1, p[i]);
    }
    free(p);
    p = NULL;
    return 0;
}

运行结果为:

同时,realloc也可以起到malloc的功能

int main()
{
    int* p = (int*) realloc(NULL,40);
    //等价于malloc(40);  
    return 0;
}
目录
相关文章
|
9月前
|
安全 C语言 C++
比较C++的内存分配与管理方式new/delete与C语言中的malloc/realloc/calloc/free。
在实用性方面,C++的内存管理方式提供了面向对象的特性,它是处理构造和析构、需要类型安全和异常处理的首选方案。而C语言的内存管理函数适用于简单的内存分配,例如分配原始内存块或复杂性较低的数据结构,没有构造和析构的要求。当从C迁移到C++,或在C++中使用C代码时,了解两种内存管理方式的差异非常重要。
329 26
|
9月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
430 15
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
570 6
|
9月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
2991 0
|
9月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
986 1
|
9月前
|
存储 弹性计算 固态存储
阿里云服务器配置费用整理,支持一万人CPU内存、公网带宽和存储IO性能全解析
要支撑1万人在线流量,需选择阿里云企业级ECS服务器,如通用型g系列、高主频型hf系列或通用算力型u1实例,配置如16核64G及以上,搭配高带宽与SSD/ESSD云盘,费用约数千元每月。
1217 0
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
1068 0
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。