std::pmr::null_memory_resource
来自 cppreference.cn
定义于头文件 <memory_resource> |
||
std::pmr::memory_resource* null_memory_resource() noexcept; |
(C++17 起) | |
返回一个指向不执行任何分配的 `memory_resource` 的指针。
[编辑] 返回值
返回一个指向 `std::pmr::memory_resource` 派生类型的静态存储期对象的指针 `p`,该对象具有以下属性:
- 其 `allocate()` 函数总是抛出 `std::bad_alloc`;
- 其 `deallocate()` 函数没有效果;
- 对于任何 `memory_resource` `r`,`p->is_equal(r)` 返回 `&r == p`。
每次调用此函数都会返回相同的值。
[编辑] 示例
该程序演示了 `null_memory_resource` 的主要用法:确保一个需要栈上分配内存的内存池在需要更多内存时不会在堆上分配内存。
运行此代码
#include <array> #include <cstddef> #include <iostream> #include <memory_resource> #include <string> #include <unordered_map> int main() { // allocate memory on the stack std::array<std::byte, 20000> buf; // without fallback memory allocation on heap std::pmr::monotonic_buffer_resource pool{buf.data(), buf.size(), std::pmr::null_memory_resource()}; // allocate too much memory std::pmr::unordered_map<long, std::pmr::string> coll{&pool}; try { for (std::size_t i = 0; i < buf.size(); ++i) { coll.emplace(i, "just a string with number " + std::to_string(i)); if (i && i % 50 == 0) std::clog << "size: " << i << "...\n"; } } catch (const std::bad_alloc& e) { std::cerr << e.what() << '\n'; } std::cout << "size: " << coll.size() << '\n'; }
可能的输出
size: 50... size: 100... size: 150... std::bad_alloc size: 183