栈内存(malloc)/递归

本文探讨了C语言中的堆内存管理,包括malloc的使用、内存清理及定义二维数组的方法。同时,文章深入讲解了函数递归的概念,如分治策略,并分析了递归的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是堆内存:

是进程的一个内存段(text\data\bss\heap\stack),是由程序员手动管理的
特点:足够大, 缺点:使用麻烦

为什么要使用堆内存:

1、随着程序的复杂数据指挥越来越多
2、其他内存段的申请释放不受控制,对内存的申请释放是受控制

如何使用堆内存:

注意:C语言中没有控制对内存的语句,只能使用C标准库提供的函数
#include<stdlib.h>

void *malloc(size_t size);
功能:从堆内存中申请size个字节的内存,申请到的内存存储是什么内存不确定
返回值:成功返回申请到的内存的首地址,失败返回NULL

void free(void *ptr);
功能:释放一块堆内存,可以释放NULL,但是不能重复释放和释放非法地址
注意:释放仅仅只是回收使用权,里面数据是不会被特意清理

void *calloc(size_t nmemb, size_t size);
功能:从堆内存中申请nmemb块size个字节的内存,申请到的内存块会被初始化为0

void *realloc(void *ptr, size_t size);
功能:改变已有内存块的大小,size表示调整后的大小
返回值:是调整后的内存块首地址,一定要重新接受该函数的返回值,
可能不是在原基础上调整的
    如果无发在原基础上调整:
        1、申请一块size大小的内存
        2、把原内存上的内容拷贝过去
        3、把原内存释放,在返回新内存的首地址

malloc的内存管理机制:

当首次向malloc申请内存时,malloc会向操作系统申请内存,操作系统会直接给33页
(一页 = 4096字节)内存交给malloc管理
但是不意味着你可以越界访问该内容因为malloc也会把内存分配给"其他人",
这样就会产生脏数据

每次申
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值