【0415】Postgres内核 释放指定 memory context 中所有内存 ④

117 篇文章 ¥119.90 ¥299.90

1. frees all memory (memory context)

Postgres内核中由函数 AllocSetReset() 完成该功能。即 “释放给定set中分配的所有内存。”

它应当将所有已分配的chunks标记为已释放,但不一定需要归还set所拥有的全部资源。我们的实际实现是,除了“保留”块(“keeper” block)(由于其与context header共享一个 malloc chunk,所以我们必须保留)之外, 我们归还所有资源。这样,在每次对上下文进行重置之前进行了少量分配的情况下,就不会频繁调用 malloc(), 这是每个元组上下文的典型行为。

1.1 函数实现逻辑

  1. 参数和初始化:

    • 接收一个 MemoryContext 参数并转换为 AllocSet 类型
    • 检查内存上下文的有效性
    • 在调试模式下会先检查内存损坏和泄漏
  2. 保留块处理

    • 计算并保存保留块(keeper block)的大小用于后续断言检查
    • 清空空闲列表(freelist)
  3. 块遍历处理

    • 将块列表重置为仅包含保留块
    • 遍历所有内存块:
      • 如果是保留块:重置其指针但不释放内存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

内核之道

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值