Maisel 2022-02-06 13:39 采纳率: 81.8%
浏览 20
已结题

C/C++free函数释放内存时如果内存块头已被修改怎么办

问题遇到的现象和发生背景

当我们采用free函数来释放某段动态分配出来的内存时,比如说该指针为p,首先free函数会将p向前移动2个字节的位置,找到内存块头,并读取出其中的内存块大小。那么如果这个内存块头的内容被改写了怎么办?

我的解答思路和尝试过的方法

网上有人说,采取一定的校验措施确保这段地址即使被破坏也能被发现。想问一下有没有更加详细具体的解答方法?

  • 写回答

2条回答 默认 最新

  • _GX_ 2022-02-06 16:01
    关注

    为了效率一般是没有校验的,因为即使校验发现被破坏,你也没办法复原。你可以看看glibc的实现
    https://code.woboq.org/userspace/glibc/malloc/malloc.c.html#malloc_chunk

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月15日
  • 已采纳回答 2月7日
  • 创建了问题 2月6日

悬赏问题

  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败
  • ¥15 树莓派5怎么用camera module 3啊
  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题