std::pmr::null_memory_resource
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <memory_resource>
|
||
std::pmr::memory_resource* null_memory_resource() noexcept; |
(начиная с C++17) | |
Возвращает указатель на memory_resource, который не выполняет никакого распределения.
Возвращаемое значение
Возвращает указатель p на объект статической длительности хранения типа, производного от std::pmr::memory_resource, со следующими свойствами:
- его функция
allocate()всегда генерирует std::bad_alloc; - его функция
deallocate()не имеет эффекта; - для любого
memory_resourcer,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()
{
// выделить память в стеке
std::array<std::byte, 20000> buf;
// без резервного выделения памяти в куче
std::pmr::monotonic_buffer_resource pool{buf.data(), buf.size(),
std::pmr::null_memory_resource()};
// выделить слишком много памяти
std::pmr::unordered_map<long, std::pmr::string> coll{&pool};
try
{
for (std::size_t i = 0; i < buf.size(); ++i)
{
coll.emplace(i, "просто строка с номером " + std::to_string(i));
if (i && i % 50 == 0)
std::clog << "размер: " << i << "...\n";
}
}
catch (const std::bad_alloc& e)
{
std::cerr << e.what() << '\n';
}
std::cout << "размер: " << coll.size() << '\n';
}
Возможный вывод:
размер: 50...
размер: 100...
размер: 150...
std::bad_alloc
размер: 155