文章目录
解决问题:PostgreSQL 7. 1 以前的版本在处理大量以指针传值的查询时一直存在着内存泄漏的问题,直到 查询结束才能将内存收回 。
从版本 7. 1 开始,系统实现了新的内存管理机制, 这样使得运行时大多数内存分配操作在各种语义的内存上下文( MemoryContext) 中进行 。 内存上 下文将放时将会释放在其中分配的所有内存,这样即使某些内存没有被任何指针指向或忘记了释 放,我们都可以通过释放内存上下文来避免这些内存泄漏 。 这一机制也使内存管理更加方便,开发 人员不必再费尽心思地处理内存军事放的工作。
程序首先调用 MemoryContextInit 创建 TopMemoryContext 和 ErrorContext0。然后调用AllocSetContextCreate以 TopMemoryContext为根节点创建 PostmasterContext. 最后将全局指针 CurrentMemoryContext 指向 PostmasterContext。 这些内存上下文的具体含义如下:
• TopMemoryContext: 在 TopMemoryContext 中分配的内存直到系统退出时才会释放。例如: TopMemoryContext 中存放了所有打开的文件描述符、内存上下文的控制节点等 。 它是所有内存上下文的树根 。
• ErrorContext: 这是错误恢复处理的永久性内存环境,恢复完毕则重设。
• PostmasterContext: 这是 Postmas