weixin_62375656 2021-11-08 12:36 采纳率: 55.6%
浏览 194
已结题

【提问】多次使用malloc函数的内存分配问题。

刚刚学到malloc,然后试着写了串代码看看重复对p用malloc,malloc的地址和程序运行的结果是什么。

#include<stdio.h>
#include<stdlib.h>
int main()
{
         int* p=0;
         p = (int*)malloc(1024 * 1024 * 100); 
         printf("%p\n", p);
         while (p != NULL)
         {
             p = (int*)malloc(1024 * 1024 * 100);
             printf("%p\n", p);
         }
    printf("%p\n", p);
}

img

p的地址一直增大直到超出分配空间会返回0这我知道。

疑惑的是:p的地址一直增大是不是因为重复做malloc之前没有free?

不理解的是:每行的p的地址都是首地址吗(我想毕竟它重新分配了,所以首地址也跟着重新变换了?)?如果是的话那之前分配过的没有free的空间去哪了?p还指向那些地方吗?

  • 写回答

2条回答 默认 最新

  • 关注

    每行的p的地址都是首地址,每次malloc后,由系统重新分配内存,所以p也会随着改变,直到没有内存可以分配(程序会崩溃)。
    没有free的空间还保留在程序中,但是因为已经让p指向了新申请的内存,所以先申请的内存已经丢失,无法再使用,这就会造成内存泄露。之前申请的那些内存空间,只会在程序结束的时候,由系统回收。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • CSDN专家-link 2021-11-08 13:07
    关注

    malloc分配的内存操作系统会认为被你这个程序占用。可是这个内存的地址由于你重复申请而丢弃了,因为p已经指向了新申请的地址,原地址没有变量记录,就再也找不回来了,只有程序运行结束后,操作系统自动回收后才能重新给其它程序分配
    p是否一直增大,这个是由操作系统的内存管理来控制的,操作系统总是寻找最合适的空间段分配给你。

    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月16日
  • 已采纳回答 11月8日
  • 修改了问题 11月8日
  • 创建了问题 11月8日

悬赏问题

  • ¥15 要求编写稀疏矩阵A的转置矩阵的算法
  • ¥15 编写满足以下要求的停车场管理程序,设停车场只有一个可停放n辆车的狭窄通道且只有一个大门可供车辆进出。
  • ¥20 powerbulider 导入excel文件,显示不完整
  • ¥15 用keil调试程序保证结果进行led相关闪烁
  • ¥15 paddle训练自己的数据loss降不下去
  • ¥20 用matlab的pdetool解决以下三个问题
  • ¥15 单个福来轮的平衡与侧向滑动是如何做到的?
  • ¥15 嵌入式Linux固件,能直接告诉我crc32校验的区域在哪不,内核的校验我已经找到了,uboot没有
  • ¥20 h3c静态路要求有详细过程
  • ¥15 调制识别中输入为时频图,星座图,眼图等