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 matlab实现基于主成分变换的图像融合。
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊