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;
}
目录
相关文章
|
2月前
|
存储 编译器 程序员
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
在C语言中,内存布局是程序运行时非常重要的概念。内存布局直接影响程序的性能、稳定性和安全性。理解C程序的内存布局,有助于编写更高效和可靠的代码。本文将详细介绍C程序的内存布局,包括代码段、数据段、堆、栈等部分,并提供相关的示例和应用。
73 5
【C语言】内存布局大揭秘 ! -《堆、栈和你从未听说过的内存角落》
|
2月前
|
存储 缓存 算法
【C语言】内存管理函数详细讲解
在C语言编程中,内存管理是至关重要的。动态内存分配函数允许程序在运行时请求和释放内存,这对于处理不确定大小的数据结构至关重要。以下是C语言内存管理函数的详细讲解,包括每个函数的功能、标准格式、示例代码、代码解释及其输出。
99 6
|
3月前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
88 6
|
3月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
1月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
62 23
|
1月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
66 15
|
1月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
60 24
|
1月前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
63 16

热门文章

最新文章