std::pmr通过memory_resource实现灵活内存管理,支持自定义分配策略;其核心组件包括memory_resource、polymorphic_allocator及多种派生资源类型,可用于高性能场景。

在C++17中,std::pmr(Polymorphic Memory Resource,多态内存资源)提供了一套灵活的内存管理机制,允许程序在不同内存池之间动态切换分配策略,而无需修改使用代码。它基于 memory_resource 抽象接口,实现运行时决定内存分配方式,适用于高性能、低延迟或需要精细控制内存布局的场景。
理解 std::pmr 的核心组件
std::pmr 的设计围绕几个关键类型展开:
- std::pmr::memory_resource:抽象基类,定义了 do_allocate 和 do_deallocate 等虚函数,用于定制内存分配行为。
- std::pmr::pool_options:配置池式资源(如 monotonic_buffer_resource)的行为参数。
- 派生资源类型:如 std::pmr::synchronized_pool_resource、std::pmr::monotonic_buffer_resource、std::pmr::null_memory_resource 等。
-
std::pmr::polymorphic_allocator
:模板分配器,绑定到某个 memory_resource 实例,供容器使用。
所有这些都位于
如何创建和使用自定义内存资源
你可以通过继承 memory_resource 来实现自己的分配逻辑,但更常见的是使用标准库提供的现成资源。
立即学习“C++免费学习笔记(深入)”;
例如,使用 monotonic_buffer_resource 创建一个基于缓冲区的快速分配器:
#include#include #include int main() { // 分配一块大缓冲区作为后端存储 char buffer[1024]; std::pmr::monotonic_buffer_resource pool{buffer, sizeof(buffer)};
// 使用该资源创建 polymorphic allocator std::pmr::polymorphic_allocatorzuojiankuohaophpcnintyoujiankuohaophpcn alloc{&pool}; // 构造一个使用此分配器的 vector std::pmr::vectorzuojiankuohaophpcnintyoujiankuohaophpcn vec{alloc}; for (int i = 0; i zuojiankuohaophpcn 100; ++i) vec.push_back(i); std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Size: " zuojiankuohaophpcnzuojiankuohaophpcn vec.size() zuojiankuohaophpcnzuojiankuohaophpcn "\n"; return 0;}
上面的例子中,所有对 vector 的内存请求都会由 pool 处理。由于 monotonic_buffer_resource 是“递增式”分配,释放操作通常被忽略(除非显式 reset),适合一次性批量分配场景。
使用 synchronized_pool_resource 进行高效对象池管理
对于频繁申请小块内存的场景(如大量 small vector 或 string),synchronized_pool_resource 更合适:
std::pmr::synchronized_pool_resource pool;// 所有使用这个资源的分配器将共享同一个池 { std::pmr::vector
v1{&pool}; v1.resize(50); std::pmr::string s1{"Hello PMR", &pool};} // 析构时自动归还内存到池中
这个资源内部维护多个按大小分类的内存池,减少碎片并提升速度。它是线程安全的(名字中的 synchronized 指此意)。
注意:你不能直接 delete 通过 pmr 分配的内存,而是依赖于容器或资源本身的生命周期管理。比如调用 pool.release() 可以释放全部池内存。
容器与 std::pmr 的集成
C++17 提供了许多 std::pmr::XXX 容器别名,它们默认使用 polymorphic_allocator:
- std::pmr::vector
- std::pmr::deque
- std::pmr::list
- std::pmr::map
- std::pmr::string
- std::pmr::unordered_set
这些容器构造时可接受 memory_resource* 参数,内部会转换为 polymorphic_allocator 并用于后续分配。
也可以手动传递分配器:
std::pmr::memory_resource* my_res = std::pmr::get_default_resource(); std::pmr::vectorvec{std::pmr::polymorphic_allocator {my_res}};
设置全局默认资源
可以使用 set_default_resource() 更改全局默认的 memory_resource:
auto* custom_pool = new std::pmr::synchronized_pool_resource; std::pmr::set_default_resource(custom_pool);// 此时新建的 pmr 容器若未指定资源,将使用 custom_pool std::pmr::vector
vf; // 自动使用 custom_pool
记得在程序结束前恢复或清理资源,避免泄漏。
基本上就这些。std::pmr 的强大之处在于它把内存分配策略从具体类型中解耦,让性能优化变得模块化且可配置。合理使用能显著提升特定场景下的效率,尤其是高频小对象分配或需要确定性内存行为的系统中。











