CarlsonC 2019-09-22 13:06 采纳率: 0%
浏览 1361
已采纳

单链表中删除节点后游离的节点怎么释放内存空间,不能用free,系统会自动回收吗?

图片说明

如上图,指针指向了红色的节点,但由于 free 函数只能作用于malloc等函数,那这里的红色的节点如何释放内存呢,不过不管,系统会不会自动回收,如果不回收,如果大量存在这样的节点,不是很占用内存吗?

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-09-22 13:10
    关注

    如果节点定义在堆栈上,比如
    int foo()
    {
    Node node1;
    Node node2;
    Node node3;
    Node node4; //“游离”
    node1.Next = &node2;
    node2.Next = &node3;
    ...
    }
    这样的代码,不需要回收,函数运行完,无论节点有没有“游离”都被回收了。

    但是如果是malloc分配的,或者间接由malloc分配的,那么必须释放,否则内存泄漏。也就是这块内存在直到程序退出以前,就死在那里了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置
  • ¥15 Matlab怎么求解含参的二重积分?
  • ¥15 苹果手机突然连不上wifi了?
  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用