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;
}
目录
相关文章
|
3月前
|
存储 C语言
`scanf`是C语言中用于按格式读取标准输入的函数
`scanf`是C语言中用于按格式读取标准输入的函数,通过格式字符串解析输入并存入指定变量。需注意输入格式严格匹配,并建议检查返回值以确保读取成功,提升程序健壮性。
1048 0
|
5月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
338 15
|
10月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
442 1
一文彻底搞清楚C语言的函数
|
5月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
1929 0
|
5月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
590 1
|
5月前
|
存储 弹性计算 固态存储
阿里云服务器配置费用整理,支持一万人CPU内存、公网带宽和存储IO性能全解析
要支撑1万人在线流量,需选择阿里云企业级ECS服务器,如通用型g系列、高主频型hf系列或通用算力型u1实例,配置如16核64G及以上,搭配高带宽与SSD/ESSD云盘,费用约数千元每月。
536 0
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
948 0
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
1043 1